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(57) Abstract: A logic circuit such 
as a parallel counter comprises 
logic for generating output bits as 
elementary symmetric functions of 
the input bits. The parallel counter 
can be used in a multiplication 
circuit. A multiplication circuit 
is also provided in which an array 
of combinations of each bit of a 
binary number with each other 
bit of another binary number is 
generated having a reduced form in 
order to reduce the steps required 
in array reduction. 
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A PARALLEL COUNTER AND A LOGIC CIRCUIT FOR PERFORMING 

MULTIPLICATION 

The present invention generally relates to digital electronic devices and more 
particularly to a digital electronic device performing binary logic. In one aspect the 
present invention relates to a parallel counter and in another aspect the present invention 
relates to a logic circuit which implements the multiplication of binary numbers. 

It is instrumental for many applications to have a block that adds n inputs of the same 
binary weight together. An output of this block is a binary representation of the number 
of high inputs. Such blocks, called parallel counters (L. Dadda, Some Schemes for 
Parallel Multipliers, Alta Freq 34: 349-356 (1965); E. E. Swartzlander Jr., Parallel 
Counters, IEEE Trans. Comput. C-22: 1021-1024 (1973)) (the content of which is 
hereby incorporated by reference), are used in circuits performing binary multiplication. 
There are other applications of a parallel counter, for instance, majority-voting decoders 
or RSA encoders and decoders. It is important to have an implementation of a parallel 
counter that achieves a maximal speed. It is known to use parallel counters in 
multiplication (L. Dadda, On Parallel Digital Multipliers, Alta Freq 45: 574-580 
(1976)) (the content of which is hereby incorporated by reference). 

A full adder is a special parallel counter with a three-bit input and a two-bit output. A 
current implementation of higher parallel counters i.e. with a bigger number of inputs is 
based on using full adders (C. C. Foster and F. D. Stockton, Counting Responders in an 
Associative Memory, IEEE Trans. Comput. C-20: 1580-1583 (1971)) (the content of 
which is hereby incorporated by reference). In general, the least significant bit of an 
output is the fastest bit to produce in such implementation while other bits are usually 
slower. 

The following notation is used for logical operations: 

© - Exclusive OR; 
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v-OR; 
a- AND; 

n«NOT. 

An efficient prior art design (Foster and Stockton) of a parallel counter uses foil adders. 
A foil adder, denoted FA, is a three-bit input parallel counter shown in figure 1 . It has 
three inputs X], X2, X3, and two outputs S and C. Logical expressions for outputs are 

S = X 1 ©X2©X3, 
C = (Xi AX2MX1AX3MX2AX3). 
A half adder, denoted HA, is a two bit input parallel counter shown in figure 1 It has 
two inputs Xi, X2 and two outputs S and C. Logical expressions for outputs are 

S=Xi0X 2 , 

: ' * • : ' C = XiaX 2 . " : 

A prior art implementation of a seven-bit input parallel counter illustrated in figure 2. 

A paper by Irving T. To and Tien Chi Chen entitled "Multiple Addition by Residue 
Threshold Functions and Their Representation by Array Logic" (IEEE Trans. Comput. 
C-22:762-767 (1973)) (the content of which is hereby incorporated by reference) 
discloses a method of adding together a collection of numbers using exact sjinmetric 
functions to implement residue threshold functions. This arrangement provides some 
improvement in speed over conventional foil adders but requires a large increase in area 
due to the need to compute exactly. 

Multiplication is a fundamental operation. Given two n-digit binary numbers 
An-^^+An^^+.-.+A^+Ao and B n .i2 nM +B n . 2 2 n " 2 +...+B*i2+Bo, 
their product 

P2n-i2 2n * ] +P 2n . 2 2 2n - 2 +. ..+P,2+P 0 
may have up to 2n digits. Logical circuits generating all Pi as outputs generally follow 
the scheme in figure 14. Wallace has invented the first fast architecture for a multiplier, 
now called the Wallace-tree multiplier (Wallace, C. S., A Suggestion for a Fast 
Multiplier* IEEE Trans. Electron. Comput EC-13: 14-17 (1964)) (the content of which 
is hereby incorporated by reference). Dadda has investigated bit behaviour in a 
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multiplier (L. Dadda, Some Schemes for Parallel Multipliers, Alta Freq 34: 349-356 
(1965)) (the content of which is hereby incorporated by reference). He has constructed a 
variety of multipliers and most parallel multipliers follow Dadda' s or Wallace's 
scheme. 

Dadda' s multiplier uses the scheme in on figure 22. If inputs have 8 bits then 64 parallel 
AND gates generate an array shown in figure 23. The AND gate sign a is omitted for 
clarity so that Aj aBj becomes AjBj. The rest of figure 23 illustrates array reduction that 
involves full adders (FA) and half adders (HA). Bits from the same column are added 
by half adders or full adders. Some groups of bits fed into a full adder are in rectangles. 
Some groups of bits fed into a half adder are in ovals. The result of array reduction is 
just two binary numbers to be added at the last step. One adds these two numbers by 
one of the fast addition schemes, for instance, conditional adder or carry-look-ahead 
adder. 

In accordance with a first aspect, the present invention provides a parallel counter based 
on algebraic properties of elementary symmetric functions. Each of the plurality of 
binary output bits is generated as an elementary symmetric function of a plurality of 
binary input bits. 

The elementary symmetric functions comprise logically AND combining sets of one or 
more binary inputs and logically OR or exclusive OR logic combining the logically 
combined sets of binary inputs to generate a binary output. The OR and the exclusive 
OR symmetric functions are elementary symmetric functions and the generated output 
binary bit depends only on the number of high inputs among the input binary bits. For 
the OR symmetric function, if the number of high inputs is m, the output is high if and 
only if m >k, where k is the size of the sets of binary inputs. Similarly, the generated 
output binary bit using the exclusive OR symmetric function is high if and only if m >k 
and the number of subsets of inputs of the set of high inputs is an odd number. In one 
embodiment the size of the sets can be selected. The i th output bit can be generated 
using the symmetric function using exclusive OR logic by selecting the set sizes to be of 
size 2\ where i is an integer from 1 to N, N is the number of binary outputs, and i 
represents the significance of each binary output. 
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In one embodiment the sets of binary inputs used in the elementary symmetric functions 
are each unique and they cover all possible combinations of binary inputs. 

In one embodiment of the present invention, the logic circuit is divided into a plurality 
of logic units. Each logic unit is arranged to generate logic unit binary outputs as a 
symmetric function of the binary inputs to the logic unit. The binary inputs are divided 
into inputs into a plurality of the logic units, and the binary outputs are generated using 
binary outputs of a plurality of the logic units. 

This embodiment reduces the amount of fan-out in the circuit and increases the amount 
of logic sharing. It thus makes parallel counters for a large binary number more .. 
practicable. - - - 

In one embodiment of the present invention, the logic circuit is divided into a plurality 
of logic units arranged hierarchically. Each logic unit is arranged to generate logic unit 
binary outputs as an elementary symmetric function of the binary inputs to the logic 
unit. Logic units at the or each lower level of the hierarchy are included in the logic of 
logic units at the or each higher level in the hierarchy and have more inputs. 

In a specific embodiment of the present invention, the logic and inputs of the parallel 
counter are divided in accordance with a binary tree. The logic circuit is divided into a 
plurality of logic units. Each logic unit is arranged to generate logic unit binary outputs 
as an elementary symmetric function of the binary inputs to the logic unit. The binary 
inputs are divided into inputs into the plurality of logic units, and the binary outputs of 
the plurality of outputs are generated using binary outputs of a plurality of the logic 
units. 

In a preferred embodiment, each of the logic units is arranged to receive 2 n of the binary 
inputs, where n is an integer indicating the level of the logic units in the binary tree, the 
logic circuit has m logic units at each level, where m is a rounded up integer determined 
from (the number of binary inputs)/ 2 n , logic units having a higher level in the binary 
tree comprise logic of logic units at lower levels in the binary tree, and each logic unit is 
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arranged to generate logic unit binary outputs as an elementary symmetric function of 
the binary inputs to the logic unit 

In one embodiment, each logic unit at the first level is arranged to generate logic unit 
binary outputs as a smallest elementary symmetric function of the binary inputs to said 
logic circuit. 

In one embodiment, each logic unit at the first level is arranged to generate logic unit 
binary outputs as an elementary symmetric function of the binary inputs to the logic 
circuit using OR logic for combining the binary inputs. 

In one embodiment, each logic unit at the first level is arranged to logically AND each 
of the binary inputs to the logic unit and to logically OR each of the binary inputs to the 
logic unit to generate the logic unit binary outputs. 

In one embodiment, each logic unit at the first level is arranged to generate logic unit 
binary outputs as an elementary symmetric function of the binary inputs to the logic 
circuit using exclusive OR logic for combining the binary inputs. 

In one embodiment, each logic unit at the first level is arranged to logically AND each 
of the binary inputs to the logic unit and to logically exclusively OR each of the binary 
inputs to the logic unit to generate the logic unit binary outputs. 

In one embodiment, elementary logic units are provided as the logic units at the first 
level for performing elementary symmetric functions, outputs from each of two primary 
elementary logic units receiving four logically adjacent binary inputs from said plurality 
of inputs are input to two secondary elementary logic units, an output from each of the 
secondary elementary logic units is input to a tertiary elementary logic unit, and the 
primary, secondary and tertiary elementary logic units form a secondary logic unit at a 
second level of the binary tree having a binary output comprising a binary output from 
each of the secondary elementary logic units and two binary outputs from the tertiary 
elementary logic unit. 
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In one embodiment, tertiary logic units at a third level of the binary tree each comprise 
two secondary logic units receiving eight logically adjacent binary inputs from the 
plurality of inputs, four elementary logic units receiving as inputs the outputs of the two 
secondary logic units, and further logic for generating binary outputs as an elementary 
symmetric function of the binary inputs to the tertiary logic unit using the binary 
outputs of the four elementary logic units. 

In one embodiment, quaternary logic units at a fourth level of the binary tree each 
comprise two tertiary logic units receiving sixteen logically adjacent binary inputs from 
the plurality of inputs, four elementary logic units receiving as inputs the outputs of the 
two tertiary logic units, and further logic for generating binary outputs as an elementary 
symmetric function of the binary inputs to the quaternary logic unit using the binary 
outputs of the four elementary logic units. - 

In one embodiment, elementary logic units are provided as the logic units at the first 
level for performing the smallest elementary symmetric functions, and logic units for 
higher levels comprise logic units of lower levels. 

In one embodiment, the logic units for higher levels above the second level comprise 
logic units of an immediately preceding level and elementary logic units. 

In one embodiment, each logic unit at each level is arranged to generate logic unit * 
binary outputs as an elementary symmetric function of the binary inputs to the logic 
circuit using OR logic for combining the binary inputs. 

In one embodiment, each logic unit at each level is arranged to generate logic unit 
binary outputs as an elementary symmetric function of the binary inputs to the logic 
circuit using exclusive OR logic for combining the binary inputs. 

In one embodiment of the present invention, each of the binary outputs can be generated 
using an elementary symmetric function which uses exclusive OR logic. However, 
exclusive OR logic is not as fast as OR logic. • 
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In accordance with another embodiment of the present invention at least one of the 
binary outputs is generated as an elementary symmetric function of the binary inputs 
using OR logic for combining a variety of sets of one or more binary inputs. The logic 
is arranged to logically AND members of each set of binary inputs and logically OR the 
result of the AND operations. 

Thus use of the elementary symmetric function using OR logic is faster and can be used 
for generation of the most significant output bit. In such an embodiment the set size is 
set to be 2 N "\ where N is the number of binary outputs and the N lb binary output is the 
most significant. 

It is also possible to use the elementary symmetric function using OR logic for less 
significant bits on the basis of the output value of a more significant bit. In such a case, 
a plurality of possible binary outputs for a binary output less significant than the N 01 are 
generated as elementary symmetric functions of the binary inputs using OR logic for 
combining a plurality of sets of one or more binary inputs, where N is the number of 
binary outputs. Selector logic is provided to select one of the possible binary outputs 
based on a more significant binary output value. The size of the sets used in such an 
arrangement for the (N-l)* bit is preferably 2 N " ] + 2 n " 2 and 2 N ~ 2 respectively and one of 
the possible binary outputs is selected based on the N** 1 binary output value. 

In one embodiment of the present invention the circuit is designed in a modular form. 
A plurality of subcircuit logic modules are designed, each for generating intermediate 
binary outputs as an elementary symmetric function of some of the binary inputs. Logic 
is also provided in this embodiment for logically combining the intermediate binary 
outputs to generate binary outputs. 

In one embodiment of the present invention, the logic units are arranged hierarchically 
and at least one logic unit in at least one level of the hierarchy implements an inverted 
elementary symmetric function. In one arrangement, the logic units at an odd number of 
levels in the hierarchy implement inverted elementary symmetric functions, logic units 
at an even number of levels in the hierarchy implement symmetric functions, and the 
inputs to the logic units at the first level of the hierarchy are inverted. In another 
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arrangement logic units at an even number of levels in the hierarchy implement inverted 
elementary symmetric functions, logic units at an even number of levels in the hierarchy 
implement symmetric functions, and the inputs to the logic units at the first level of the 
hierarchy are input to logic units in a first level in the hierarchy uninverted. This 
embodiment of the present invention allows faster inverting logic gates to be used in the 
logic circuit. 

Since OR logic is faster, in a preferred embodiment the subcircuit logic modules 
implement the elementary symmetric functions using OR logic. In one embodiment the 
subcircuit modules can be used for generating some binary outputs and one or more 
logic modules can be provided for generating other binary outputs in which each logic 
module generates a binary output as an elementary symmetric function of the binary 
inputs exclusive OR logic for combining a plurality of sets of one or more binary inputs. 

Another aspect of the present invention provides a method of designing a logic circuit 
comprising: providing a library of logic module designs each for performing a small 
elementary symmetric function; designings logic circuit to perform a large elementary 
symmetric function; identifying small elementary symmetric functions which can 
perform said elementary symmetric function; selecting logic modules from said library 
to perform said small elementary symmetric functions; identifying a logic circuit in the 
selected logic circuit which performs an elementary symmetric function and which can 
be used to perform another elementary symmetric function; selecting the logic circuit 
corresponding to the identified elementary symmetric function and using the selected 
logic circuit with inverters to perform said other elementary symmetric function using 
the relationship between the elementary symmetric functions: 

OR_n_k(X,...X n ) = -iOR_n_(n+l-k)(-.Xi...«iX n ) 
where -i denotes an inversion, n is the number of inputs, and k is the number of sets of 
inputs AND combined together. 

Another aspect of the present invention provides a conditional parallel counter having m 
possible high inputs out of n inputs, where m<n, and n and m are integers, the counter 
comprising the parallel counter for counting inputs to generate p outputs for m inputs, 
wherein the number n of inputs to the counter is greater than 2 P , where p is an integer. 
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Thus these aspects of the present invention provide a fast circuit that can be used in any 
architecture using parallel counters. The design is applicable to any type of technology 
from which the logic circuit is built. 

The parallel counter in accordance with this aspect of the present invention is generally 
applicable and can be used in a multiplication circuit that is significantly faster than 
prior art implementations. 

One aspect of the present invention provides a conditional parallel counter having m 
possible high inputs out of n inputs, where m<n, and n and m are integers. The 
conditional parallel counter comprises the parallel counter as described hereinabove for 
counting inputs to generate p outputs for m inputs, wherein the number n of inputs to 
the counter is greater than 2 P . The conditional multiplier can be used in a digital filter 
for example. 

In accordance with another aspect of the present invention a technique for multiplying 
binary numbers comprises an array generation step in which an array of logical 
combinations between the bits of the two binary numbers is generated which is of 
reduced size compared to the prior art. 

In accordance with this aspect of the present invention, a logic circuit for multiplying 
two binary numbers comprises array generation logic for performing a logical binary 
operation between each bit in one binary number and each bit in the other binary 
number to generate an array of logical binary combinations comprising an array of 
binary values, and for further logically combining logically adjacent values to reduce 
the maximum depth of the array to below N bits, where N is the number of bits of the 
largest of the two binary numbers; array reduction logic for reducing the depth of the 
array to two binary numbers; and addition logic for adding the binary values of the two 
binary numbers. 

In one embodiment, when two binary numbers are multiplied together, as is 
conventional, each bit A; of the first binary number is logically combined with each bit 
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Bj of the second number to generate the array which comprises a sequence of binary 
numbers represented by the logical combinations, Ai and Bj. The further logical 
combinations are carried out by logically combining the combinations Ai and Bn-2, Ai 
and Bn-i, Ao and Bn-2, and Ao and Bn-w where N is the number of bits in the binary 
numbers. In this way the size of the maximal column of numbers to be added together 
in the array is reduced. 

More specifically the array generation logic is arranged to combine the combinations Ai 
AND Bn-2 and Ao AND B n -i using exclusive OR logic to replace these combinations and 
to combine Aj AND Bn-i and Ao AND B n -2 to replace the Aj AND B n .i combination. 

In one embodiment of the present invention the array reduction logic can include at least 
one of: at least one full adder, at least one half adder, and at least one parallel counter. 
The or each parallel counter can comprise the parallel counter in accordance with the 
first aspects of the present invention. 

This aspect of the present invention provides a reduction of the maximal column length 
in the array thereby reducing the number of steps required for array reduction. When 
the first aspect of the present invention is used in conjunction with the second aspect of 
the present invention, an even more efficient multiplication circuit is provided. 

One embodiment of the present invention provides a multiply-accumulate logic circuit 
comprising the logic circuit as described hereinabove, wherein said array generation 
logic is arranged to include an accumulation of previous multiplications. 

Another aspect of the present invention provides a logic circuit comprising at least four 
inputs for receiving a binary number as a plurality of binary inputs; at least one output 
for outputting binary code; and logic elements connected between the plurality of inputs 
and the or each binary output and for generating the or each binary output in accordance 
with a threshold function implemented as a binary tree and having a threshold of at least 
2. A threshold function is a function which is high if, and only if, at least a threshold 
number k of the inputs are high, where. k>2. 
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In one embodiment of this aspect of the present invention, the logic elements are 
arranged to generate the or each binary output as an elementary symmetric function of 
the binary inputs i.e. the threshold function is implemented as an elementary symmetric 
function. 

Another aspect of the present invention provides a logic circuit comprising at least four 
inputs for receiving a binary number as a plurality of binary inputs; at least one output 
for outputting binary code; and logic elements connected between the plurality of inputs 
and the plurality of binary outputs arranged to generate the or each of the plurality of 
binary outputs as an elementary symmetric function of the binary inputs. 

A further aspect of the present invention provides a method and system for designing a 
logic circuit comprising a plurality of inputs for receiving a binary number as a plurality 
of binary inputs, at least one output for outputting binary code, and logic elements 
connected between the plurality of inputs and the or each binary output and arranged to 
generate the or each binary output as a threshold function of the binary inputs. The 
method comprises determining logic elements for performing the threshold functions; 
and reducing the logic elements by identifying logic elements performing a logical 
AND of two threshold functions and reducing the identified logic elements to logic 
elements for performing the threshold function having the higher threshold, and 
identifying logic elements performing a logical OR of two threshold functions and 
reducing the identified logic elements to logic elements for performing the threshold 
function having the lower threshold. 

This aspect of the present invention can be implemented in software using a computer 
system comprising one or multiple networked computers. The invention thus 
encompasses program code for controlling a computer system. The code can be 
provided to the computer system on any suitable carrier medium such as a storage 
medium e.g. a floppy disk, hard disk, CD ROM, or programmable memory device, or a 
transient medium e.g. an electrical, optical, microwave, acoustic, or RF signal. An 
example of a transient medium is a signal carrying the code over a network such as the 
Internet. 
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A further aspect of the present invention provides a method and system for designing a 
logic circuit comprising a plurality of inputs for receiving a binary number-as a plurality 
of binary inputs, at least one output for outputting binary code, and logic elements 
connected between the plurality of inputs and the binary outputs and arranged to 
generate each binary output as a symmetric function of the binary inputs. The method 
comprises designing the logic circuit using exclusive OR logic; identifying any logic 
which cannot have inputs that are high at the same time; and replacing the identified 
exclusive OR logic with OR logic. 

In one embodiment of this aspect of the present invention, the logic circuit is designed 
to generate each binary output as an elementary symmetric function of the binary inputs. 

In a specific embodiment of this aspect of the present invention, the logic circuit 
comprises a parallel counter. 

This aspect of the present invention can be implemented in software using a computer 
system comprising one or multiple networked computers. The invention thus 
encompasses program code for controlling a computer system. The code can be 
provided to the computer system on any suitable carrier medium such as a storage . 
medium e.g. a floppy disk, hard disk, CD ROM, or programmable memory device, or a 
transient medium e.g. an electrical, optical, microwave, acoustic, or RF signal. An 
example of a transient medium is a signal carrying the code over a network such as the 
Internet. 

A further aspect of the present invention provides a method and system for designing a 
logic circuit comprising providing a library of logic module designs each for performing 
a small symmetric function; designing a logic circuit to perform a large symmetric 
function; identifying small symmetric functions which can perform said symmetric 
function; selecting logic modules from said library to perform said small symmetric 
functions; identifying a logic circuit in the selected logic circuit which performs a . . 
symmetric function and which can be used to perform another symmetric function; and 
selecting the logic circuit corresponding to the identified symmetric function and using 
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the selected logic circuit with inverters to perform said other symmetric function using 
the relationship between the symmetric functions: 

OR_n_k(Xi...X n ) - -,ORn_(n+l-k)(-nXi...-iX„) 
where denotes an inversion, n is the number of inputs, and k is the number of sets of 
inputs AND combined together. 

In one embodiment of this aspect of the present invention, the symmetric functions are 
elementary symmetric functions. 

This aspect of the present invention can be implemented in software using a computer 
system comprising one or multiple networked computers. The invention thus 
encompasses program code for controlling a computer system. The code can be 
provided to the computer system on any suitable carrier medium such as a storage 
medium e.g. a floppy disk, hard disk, CD ROM, or programmable memory device, or a 
transient medium e.g. an electrical, optical, microwave, acoustic, or RF signal. An 
example of a transient medium is a signal carrying the code over a network such as the 
Internet. 

Embodiments of the present invention will now be described with reference to the 
accompanying drawings, in which: 

Figure 1 is a schematic diagram of a full adder and a half adder in accordance with the 
prior art, 

Figure 2 is a schematic diagram of a parallel counter using full adders in accordance 
with the prior art, 

Figure 3 is a schematic diagram illustrating the logic modules executing the symmetric 
functions for the generation of binary outputs and the multiplexor (selector) used for 
selecting outputs, 

Figure 4 is a diagram illustrating the logic for implementing the symmetric function 
OR_3_l according to one embodiment of the present invention, 
Figure 5 is a diagram illustrating the logic for implementing the symmetric function 
OR_4_l according to one embodiment of the present invention, 
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Figure 6 is a diagram illustrating the logic for implementing the symmetric function 
OR_5_l using 2 3 input OR gates according to one embodiment of the present 
invention, 

Figure 7 is a diagram illustrating the logic for implementing the symmetric function 
EXOR_7_l using two input exclusive OR gates according to one embodiment of the 
present invention, 

Figure 8 is a diagram illustrating the logic for implementing the symmetric function 

OR_3_2 according to one embodiment of the present invention, 

Figure 9 is a diagram illustrating the logic for implementing the symmetric function 

EXOR__5_3 according to one embodiment of the present invention, , 

Figure 10 is a diagram illustrating a parallel counter using the two types of symmetric 

functions and having seven inputs and three outputs according to one embodiment of 

the present invention, 

Figure 1 1 is a diagram illustrating splitting of the symmetric function OR_7_2 into sub 
modules to allow the reusing of smaller logic blocks according to one embodiment of 
the present invention, ... 

Figure 12 is a diagram of a parallel counter using the EXORJ7_l symmetric function 
for the generation of the least significant output bit from all of the input bits, and 
smaller modules implementing symmetric functions using OR logic to generate the 
second and third output bits according to one embodiment of the present invention, 
Figure 13 is a another diagram of a parallel counter similar to that of Figure 12 accept 
that the partitioning of the inputs is chosen differently to use different functional sub- 
modules according to one embodiment of the present invention, 

Figure 14 is a diagram schematically illustrating the binary tree organisation of the logic 
in a parallel counter according to a second aspect of the invention, 
Figure 15 is a diagram illustrating the logic block (Block 1) for implementing the 
elementary symmetric functions OR_2__2 and OR_2_l according to one embodiment of 
the present invention, 

Figure 16 is a diagram illustrating the logic block (Block 2) for implementing the 
secondary symmetric functions OR_4_4, OR_4_3, OR_4_2 and OR_4_l according to 
one embodiment of the present invention, 
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Figure 17 is a diagram illustrating the logic block (Block 3) for implementing the 
tertiary symmetric functions OR_8_8, OR_8_7, OR_8_6, OR_8_5, OR_8_4, OR_8_3, 
OR_8_2 and OR_8_l according to one embodiment of the present invention, 
Figure 18 is a diagram illustrating the logic block (Block 4) for implementing the 
symmetric functions OR__15_12, OR_15_8 and OR_15_4 according to one embodiment 
of the present invention, 

Figure 19 is a diagram illustrating the logic block (Block 5) for implementing the 
elementary symmetric functions EXOR_4_2 and OR 4 1 according to one embodiment 
of the present invention, 

Figure 20 is a diagram illustrating the logic block (Block 6) for implementing the 
elementary symmetric functions EXOR_15_2 and OR_15_l according to one 
embodiment of the present invention, 

Figure 21 is a diagram schematically illustrating a parallel counter using the logic 
blocks of Figures 15 to 20 according to one embodiment of the present invention, 
Figure 22 is a diagram illustrating a hierarchical structure for logic units in accordance 
with an embodiment of the present invention, 

Figure 23 is a diagram illustrating another hierarchical structure for logic units in 
accordance with an embodiment of the present invention, 

Figure 24 is a diagram illustrating a further hierarchical structure for logic units in 
accordance with an embodiment of the present invention, 

Figure 25 is a diagram illustrating the hierarchical organisation of logic units in a tree 
structure to implement the elementary symmetric function OR_8_4 in accordance with 
an embodiment of the present invention, 

Figure 26 is a diagram of the logic for a high speed implementation of the first level the 
circuit of figure 25, 

Figure 27 is a diagram of the logic for a high speed implementation of the second level 
the circuit of figure 25, 

Figure 28 is a diagram of the logic for a high speed implementation of the third level the 
circuit of figure 25, 

Figure 29 is a diagram of the steps used in the prior art for multiplication, 
Figure 30 is a schematic diagram of the process of Figure 29 in more detail, 
Figure 31 is a diagram illustrating the properties of diagonal regions in the array, 
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Figure 32 is a diagram illustrating array deformation in accordance with the 
embodiment of the present invention and the subsequent steps of array reduction and 
adding, 

Figure 33 is a diagram of logic used in this embodiment for array generation, and 
Figure 34 is a diagram of a logic circuit for generating an output as a threshold function* 

A first aspect of the present invention will now be described. 

The first aspect of the present invention relates to a parallel counter counting the 
number of high values in a binary number. The counter has i outputs and n inputs 
where i is determined as being the integer part of log* n plus 1 

A mathematical basis for the first aspect of the present invention is a theory of 
symmetric functions. We denote by C n kthe number of distinct k element subsets of a set 
of n elements. We consider two functions EXOR_n_k and OR_n_k of n variables Xj, 
X 2 , ... Xngivenby . / 

- EXOR_n_k(X l5 X 2 , ...Xn) = e(Xn AXiaA... AX ik ), 
OR_nJc(Xi, X 2 , ... X n ) = v (Xi! a Xi2 a ... aX*) 
where (il, i2, ... ik) runs over all possible subsets of {X|, X 2 , ... X n } that contain 
precisely k elements. Blocks that produce such outputs are shown on figure 3. 

The functions EXOR_n_k and OR_nJk are elementary symmetric functions. Their 
values depend only on the number of high inputs among Xi, X 2 , X3, . . . X n . More 
precisely, if m is the number of high inputs among Xi, X 2 , X3, . . . X n then OR_nJk(Xi, 
X 2 , ... X n ) is high if and only if m>k. Similarly, EXOR_nJk(X,, X 2 , ... X n ) is high if 
and only if m>k and C m k is odd. 

Although EXOR_n_k and ORjaJc look similar, OR_n_Je is much faster to produce 
since EXOR-gates are slower than OR-gates. 

In the above representation n is the number of inputs and k is the size of the subset of 
inputs selected. Each set ofk inputs is a unique set and the subsets comprise all 
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possible subsets of the set of inputs. For example, the symmetric function OR_3_l has 
three inputs Xi , X2 and X3 and the set size is 1 . Thus the sets comprise Xi, X2 and X3. 
Each of these sets is then logically OR combined to generated the binary output. The 
logic for performing this function is illustrated in Figure 4. 

Figure 5 illustrates the logic for performing the symmetric OR_4_l . 

When the number of inputs become large, it may not be possible to use simple logic. 

Figure 6 illustrates the use of two OR gates for implementing the symmetric function 
OR_5_l. 

Figure 7 similarly illustrates the logic for performing EXOR_7_l . The sets comprise 
the inputs Xi, X2, X3, X4, X5 ^6, and X7. These inputs are input into three levels of 
exclusive OR gates. 

When k is greater than 1, the inputs in a subset must be logically AND combined. 
Figure 8 illustrates logic for performing the symmetric function OR_3J2. The inputs Xj 
and X2 comprise the first set and are input to a first AND gate. The inputs Xi and X3 
constitute a second set and are input to a second AND gate. The inputs X2 and X3 
constitute a third set and are input to a third AND gate. The output of the AND gates 
are input to an OR gate to generate the output function. 

Figure 9 is a diagram illustrating the logic for performing the symmetric function 
EXOR_5__3. To perform this function the subsets of size 3 for the set of five inputs 
comprise ten sets and ten AND gates are required. The output of the AND gates are 
input to an exclusive OR gate to generate the function. 

The specific logic to implement the symmetric functions will be technology dependent. 
Thus the logic can be designed in accordance with the technology to be used. 

In accordance with a first embodiment of the present invention the parallel counter of 
each output is generated using a symmetric function using exclusive OR logic. 
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Let the parallel counter have n inputs Xi, ... X n and t+1 outputs S t , S x .u ... So- .So is the 
least significant bit and S t is the most significant bit. For all i from 0 to t, 

SpEXORjri^CXi, X 2 , ... X n ). 

It can thus be seen that for a seven bit input i.e. n=7, i will have values of 0, 1 and 2. 
Thus to generate the output S 0 the function will be EXOR_7_l, to generate the output 
Si the function will be EXORJ7J2 and to generate the output S2 the function will be 
EXORJ7_4. Thus for the least significant bit the set size (k) is 1 , for the second bit the 
set size is 2 and for the most significant bit the set size is 4. Clearly the logic required 
for the more significant bits becomes more complex and thus slower to implement. 

Thus in accordance with a second embodiment of the present invention, the most 
significant output bit is generated using a symmetric function using OR logic. 

This is more practical since OR_n_Jc functions are faster than EXORjnJc functions. For 
the most significant output bit 

. ■ . Sk^Rja_2 t (Xi,X a ,...X il ). . 

In particular, with a seven-bit input. 

S2 == OR_7_4(Xi, X2, X3, X4, X5, X6, X 7 ).. 

Thus in this second embodiment of the present invention the most significant bit is , 
generated using symmetric functions using OR logic whereas the other bits are 
generated using symmetric functions which use exclusive OR logic. 

A third embodiment will now be described in which intermediate bits are generated 
using symmetric functions using OR logic. 

An arbitrary output bit can be expressed using OR_n_k functions if one knows bits that 
are more significant For instance, the second most significant bit is given. by 

S t -i = (St a ORjaJl 1 *! 1 ' 1 ) v ((-nS t ) a OR_n2 M ). 
In particular, with a seven-bit input 

Si = (S 2 a OR_7J5(Xi, X 2 , X 3 , X4, X 5 , X6, X 7 )) v 
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((-nS 2 ) a OR_7_2(X u X 2 , X 3 , X4, X 5 , X*. X 7 )). 
A further reduction is 

Si = ORJ7_6(X u X 2 , X 3 , X4, X 5 , X*, X 7 ) v 
((-,S 2 ) a OR_7_2(X,, X 2 , X 3 , X4, X 5 , X 6 , X 7 )). 
A multiplexer MU 5 shown in figure 3, implements this logic. It has two inputs Xo, Xj, a 
control C, and an output Z determined by the formula 

Z = (C a X0 v ((-.C) a X 0 ). 
It is not practical to use either EXOR_n_k functions or OR_n_k functions exclusively. 
It is optimal to use OR_n_k functions for a few most significant bits and EXOR_n_k 
functions for the remaining bits. The fastest, in TSMC.25, parallel counter with 7 inputs 
is shown in figure 10. 

Future technologies that have fast OR_15_8 blocks would allow building a parallel 
counter with 15 inputs. A formula for the third significant bit using OR_n_m functions 
is thus: 

S t -2 = (S t a S t -i a OR_n_2 t +2 t - , +2 t - 2 ) v (S t a (-*S t -i) a OR_n_2 t +2 t_2 ) v 
((-,S t ) a S t -i a ORjzJl^+l 1 - 2 ) v ((-,S t ) a (iSm) a OR_n2 1 - 2 ). 

A fourth embodiment of the present invention will now be described which divides the 
logic block implementing the symmetric function into small blocks which can be 
reused. 

An implementation of OR_7_2 is shown in figure 11. The 7 inputs are split into two 
groups: five inputs from Xi to X5 and two remaining inputs X6 and X7. Then the 
following identity is a basis for the implementation in figure 11. 

ORJ7_2(X w ... , X 7 ) = OR_5_2(Xi, X 5 ) v 
(OR_5_l(X], ... X 5 ) a OR_2_l(X 6 , X 7 )) v OR_2_2(X 6 , X 7 ) 
One can write similar formulas for ORJ7_4 and ORJ7_6. Indeed, 
OR_7_4(X,,... , X 7 ) - OR_5_4(Xi, X 5 ) v 
(OR_5_3(X u ... X 5 ) a OR__2_l(X 6 , X 7 )) v 
(OR_5_2(X! , . . X 5 ) a ORJ2_2(X6, X 7 )), 
OR_7_6(X l9 ...,X 7 ) = 
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(OR_5_5(X u ... X 5 ) a OR_2_l(X6, X 7 )) v 

(OR_5_4(Xi, ... X5) a OR_2_2(X6, X7)). 
Thus, it is advantageous to split variables and reuse smaller OR_n_k functions in a 
parallel counter. For instance, an implementation of a parallel counter based on 
partitioning seven inputs into groups of two and five is in figure 12. 

Similarly, one can partition seven inputs into groups of four and three. An 
implementation of the parallel counter based on this partition is in figure 13. One uses 
the following logic formulas in this implementation. 

' OR_7_2(Xi, X 7 ) = OR_4J2(Xi, X 2 , X 3 , X4) v 

(OR_4_l (X,, X 2 , X 3 , X4) a OR_3_l (X 5 , Xs, X 7 )) v OR_3_2(X 5 , Xfi, X 7 ), ; 
OR_7_4(Xi, X 7 ) = OR_4_4(X b X 2 , X 3 , X4) v 
' (OR_4_3(X 19 X2 9 X3 9 X 4 )aOR - 3 - 1(X 5 ,X 6 ,X 7 )) v 
(OR_4_2(X,, X 2 , X 3 , X4) a OR_3_2(X 5 , X 6 , X 7 )) v 
(OR_4_l (X,, X 2 , X 3 , X4) a OR_3_3(X 5 , Xe, X 7 )), 

OR_7_6CXi, ...,X 7 ) = 
(OR„4_4(X l9 X 2 , X 3 , X4) a OR_3_2(X 5 , Xe, X 7 )) v 
(OR„4_3(Xi, X 2 , X 3 , X4) a OR_3_3(X 5 , X 6 , X 7 )). 

One needs a method to choose between the implementations in figures 12 and 13. Here 
is a pneumonic rule for making a choice. If one or two inputs arrive essentially later 
then one should use the implementation on figure 12 based on partition 7=5+2. 
Otherwise, the implementation on figure 13 based on partition 7=4+3 is probably 
optimal. 

Parallel counters with 6, 5, and 4 inputs can be implemented according to the logic for 
the seven input parallel counter. Reducing the number of inputs decreases the area 
significantly and increases the speed slightly. It is advantageous to implement a six 
input parallel counter using partitions of 6, 3 + 3 or 4 + 2. 

A preferred embodiment of the present invention will now be described with reference 
to figures 14 to 21. 
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Although it is possible to implement any OR_n_k or EXOR__n_k function in two levels 
of logic, the fan-out of each input is very high and the fan-in of the OR gate is also very 
high. It is known that both high fan-out and high fan-in contribute significantly to the 
delay of the circuit. It is often required that more than one OR_nJk or EXOR_n_k 
function be computed from the same inputs. A two level implementation does not allow 
sharing of logic thus resulting in high area. 

This embodiment of the present invention uses the binary tree splitting of the inputs and 
the logic to reduce fan-out and enable reuse of logic. Figure 14 illustrates schematically 
the organisation of the logic. At a first level 8 elementary logic blocks 1 are used each 
having two of the binary inputs and providing 2 outputs. The elementary logic blocks 1 
of the first level perform elementary symmetric functions. These can either be exclusive 
OR symmetric functions or OR symmetric functions. At the second level four secondary 
logic blocks 2 each use the logic of two elementary logic blocks 1 and hence have four 
inputs and four outputs. The secondary logic blocks 2 perform larger symmetric 
functions. At the third level two tertiary logic blocks 3 each use the logic of two 
secondary logic blocks 2 and hence have eight inputs and eight outputs. The tertiary 
logic blocks 3 perform larger symmetric functions. At the fourth level the parallel 
counter 4 uses the logic of two tertiary logic blocks 3 and hence has sixteen inputs and 
sixteen outputs. 

As can be seen in figure 14, the binary tree arrangement of the logic enables the logic 
for performing smaller symmetric functions to be used for the parallel counter. Also the 
arrangement provides for significant logic sharing. This significantly reduces fan-out . 

As will be described in more detail, it is also possible to provide further logic sharing by 
using the elementary symmetric function logic for combining outputs of previous logic 
blocks in the binary tree. 

The functions OR_16_8, ORJ6_4 and OR_16__12 are constructed from the set of 
inputs Xi, X2...X16. Although, the embodiment is described with OR_n_k functions the 
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same construction applies to EXOR_n_k functions after replacing every OR gate by an 
EXOR gate. 

The principles behind this embodiment of the invention will now be described. The 
function OR_(r+s)_t can be computed as the OR of the functions OR_r_k A OR_s_t-k as 
t runs through 0,1,2.. .k, 

OR_(r*-s)_tpCi...X I+s ) = v^ 1 [OR_rJc(Xi...Xr) A OR_sJt-k)(X rH ...X r+s )]. 

In an embodiment with 16 inputs, at a first level the 16 inputs are divided into 8 subsets 
-{X i,X 2 }, {X3,X4},...,{Xi5,Xi6}, each subset containing two inputs. For each subset a 
logic block 1 that computes OR_2_l and OR_2_2 is constructed. The 8 blocks form the 
first level of the tree. Since each input fans out into an OR gate and an AND gate we see 
that each input has a fan-out of two. Also the first layer is very regular consisting of 8 
identical blocks. The logic block 1 for computing the symmetric functions OR_2_l and 
OR_2_2 is illustrated in figure 15. 

At a second level, 4 logic blocks 2 are formed by combining outputs from two adjacent 
logic blocks 1 at level one. These 4 blocks comprise the second layer of the tree. Each 
block has as inputs the outputs of two adjacent blocks from level one. The inputs are 
combined to form the functions OR_4_l, OR_4_2, OR_4_3, OR_4_4. The logic block 
2 for computing these symmetric functions is illustrated in figure 16. The indices 1 and 
2 are used in the equations below to distinguish functions formed on different subsets of 
the set of inputs. The symmetric functions can be represented as: 

OR4_l ■ = [OR_2_l]] v [OR_2_l] 2 , 
OR_4_2 = ([OR2_l]i A [OR_2 J] 2 ) v ([OR_2_2]i+[OR_2J2] 2 ), 
OR_4_3 - ([OR_2_l]^ [OR_2_2] 2 ) v ([OR_2_2]j A [OR_2_l] 2 ), 
OR_4_4 = [OR_2_2]i A [OR_2_2] 2 . 

At a third level, 2 logic blocks 3 are formed by combining outputs from two adjacent 
logic blocks 2 at level two. These 2 blocks comprise the third layer of the tree. Each 
block has as inputs the outputs of two adjacent blocks from level two. The inputs are 
combined to form the functions OR_8_l, OR_8_2, OR_8_3, OR_8_4, OR_i8_5, 
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OR_8_6, OR_8_7 and OR_8_8. The logic block 3 for computing these symmetric 
functions is illustrated in figure 17. The symmetric functions can be represented as: 

OR_8_l = [OR_4_l], v [OR_4_l] 2 , 
OR_8_2 = ([OR_4_l]i A [OR_4_l] 2 ) v [OR_4_2]i v [OR_4_2] 2 , 
OR_8_3 = ([OR_4_l] i A [OR_4_2] 2 ) v 
([OR_4_2], A [OR_4_l] 2 ) v [OR_4_3], v [OR_4_3] 2 , 
OR_8_4 = ([OR_4_l]i A [OR_4_3] 2 ) v «OR_4_2], A [OR_4_2] 2 ) v 

([OR_4_3]i A [OR_4_l] 2 ) v [OR_4_4]i v [OR_4_4] 2 , 
OR_8_5 = ([OR_4_l], A [OR_4_4] 2 ) v ([OR_4_2], A [OR_4_3] 2 ) v 
([OR_4_3], A [OR_4_2] 2 ) v ([OR_4_4] , A [OR_4_l] 2 ), 

OR_8_6 = ([OR_4_2]i A [OR_4_4] 2 ) v 
([OR_4_3], A [OR_4_3] 2 ) v ([OR_4_4], A [OR_4_2] 2 ), 
OR_8_7 = ([OR_4_3]i A [OR_4_4] 2 ) v ([OR_4_4], A [OR_4_3] 2 ), 
OR_8_8 = [OR_4_4] 1 A [OR_4_4] 2 . 

At the final level, 3 outputs are formed by combining outputs from the two adjacent 
logic blocks 3 at level 3. This logic comprises the third layer of the tree. Outputs of the 
two adjacent blocks from level three are combined to form the functions OR_16_8, 
OR_16_4, and OR_16_12. The logic block 4 for computing these symmetric functions 
is illustrated in figure 18. The symmetric functions can be represented as: 

OR_16_4 = ([OR_8_l], A [OR_8_3] 2 ) v ([OR_8_2]i A [OR_8_2] 2 ) v 

([OR_8_3], A [OR_8_l] 2 ) v [OR_8_4], v [OR_8_4] 2 , 
OR_16V_8 - ([OR_8_l], A [OR_8_7] 2 ) v ([OR_8_2], A [OR_8_6] 2 ) v 
([OR_8_3]i A [OR_8_5] 2 ) v ([OR_8_4], A [OR_8_4] 2 ) v ([OR_8_5], A [OR_8_3] 2 ) v 
([OR_8_6]i A [OR_8_2] 2 ) v ([OR_8_7], A [OR_8_l] 2 ) v [OR_8_8]! v [OR_8_8] 2 , 

OR_16_12 = ([OR_8_4], A [OR_8_8] 2 ) v ([OR_8_5], A [OR_8_7] 2 ) v 
([OR_8_6]i A [OR_8_6] 2 ) v ([OR_8_7], A [OR_8_5] 2 ) v ([OR_8_8], A [OR_8_4] 2 ). 

Whilst it is possible in accordance with the invention to generate all of the outputs of 
the parallel counter using the outputs of the logic blocks 3, it is advantageous to 
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determine the two least significant bits separately in parallel. This is illustrated in 
figures 19 and 20. Although this increases fan-out slightly, it decreases the depth of the 
tree thus increases the speed of the circuit. 

Figure 19 is a diagram of a logic block 5 for determining the symmetric functions 
EXOR4_2 and EXOR_4_l. In the determination of EXOR_4_2 the faster OR gate 
replaces an EXOR gate, according to: 

EXOR_4_2 = ([OR_2_l] l A [OR_2_l] 2 )©[OR_2__2] l e[OR - 2_2]2= 
= ([OR_2_l], A [OR_2_l] 2 ) v ([OR_2_2]i©[OR_2„2] 2 ). 
Four of these logic blocks 5 are provided to take the 16 inputs. Thus the logic block 5 
can be considered to be a combined level 1 and 2 implementation. 

In figure 19 the final logic gate is not and EXOR gate but an OR gate. This is because 
both of the inputs to the gate cannot be high at the same time i.e. AB=0 and thus the 
relationship A©B= AvB holds. Thus in accordance with one aspect of the present 
invention, faster OR gates can be included in the design of a logic circuit by identifying 
situations where this relationship holds. This process can be performed automatically by 
a computer program during logic circuit design. 

Figure 20 is a diagram of a logic block 6 for determining the symmetric functions 
EXOR__15_2 and EXOR_15_l which comprise the least two significant bits output 
from the parallel counter of this embodiment. This logic block comprises level 3 in the 
binary tree and it uses four of the logic blocks 5. Thus even in this parallel 
determination of the least significant two bits, there is reuse of logic using the binary 
tree structure.. 

Figure 21 is a diagram of the parallel counter of this embodiment of the invention in 
which the logic of block 4 is used to determine the most significant bits and the logic of 
block 6 is used to determine the least significant bits. 

In the logic blocks illustrated in figures 16, 17 and 18, it can be seen that in addition to 
sharing logic for the inputs, the outputs of the elementary logic blocks, the secondary 
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logic blocks and the tertiary logic blocks are input into elementary logic blocks thus 
providing further logic sharing. The reason for this is that OR functions are not 
independent. Assuming that k>s, 

OR_nJc a OR_n_s = OR_n_k, 1 

OR_n_k v OR_n_s = OR_n_s 2 

This shows that there are possible redundant AND and OR logical operations in the 
multiplexing operation for the outputs of logic performing small elementary symmetric 
functions to implement large elementary symmetric functions. 

These formulas result in significant reductions in logic for parallel counter. The first 
instance of such a reduction is the following formula for the second most significant bit 
of a parallel counter, 

Sm = OR - n_(2 t +2 t " 1 ) v HOR_n_2 l a OR_n_2 M ]. 

For example, in the circuit of figure 10, the multiplexor (MU) generates Si using 
OR(7,4), OR(7,6) and OR(7,2). In unreduced for the logic to generate Si is: 

Si = [OR(7,4) a OR(7,6)] v [-,OR(7,4) a OR(7,2)] 
Using the equations 1 and 2 above, this reduces to: 

Si = OR(7,6) v [-^(7,4) a OR(7,2)] 
It can thus be seen that the function OR(7,4) is redundant in the determination of Si . 

In the circuit of figure 21, the multiplexing in performed by the three logic gates. In 
unreduced form the output S2 would be: 

S 2 = [OR(15,8) a OR(15,12)] v [-nOR(15,8) a OR(15,4)] 
Using the equations 1 and 2 given above, this reduces to: 

S 2 = OR(15,12) v [-nOR(15,8) a OR(15,4)] 
This is the logic illustrated in figure 21 comprising the three logic gates for combining 
the outputs of block 4 i.e. an inverter, an AND gate and an OR gate. 

Thus this process of reduction can be implemented during the logic circuit design 
process to identify where the relationship given in equations 1 and 2 hold thus enabling 
a reduction in logic to be implemented. 
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To show the second instance of such a reduction, it is assumed that k>s, 
([OR_n_k] i A[OR_m_s] 2 ) v ([OR_m_s] , a [OR_n_k] 2 ) = 
[OR_m_s]iA[OR_m_sJ 2 A([OR_n_k]i v [OR_n_k] 2 ). 
These formulas allow the reduction of fan-out by sharing certain logic. As shown on 
block 2, the functions OR_4_2 and OR_4_3 are implemented by three levels of shared 
logic, 

OR_4_l = [OR_2_l]i v [OR_2_l] 2 , 
OR_4_2 = ([OR_2_1],a[OR_2_1] 2 ) v [OR_2_2]i v [OR_2_2] 2 , 
OR_4_3=[OR_2_1]ia[OR_2_1] 2 a ([OR_2_2], v [OR_2_2] 2 ), 

OR_4_4 = [OR_2_2], A [OR_2_2] 2 . 

Block 3 is a circuit implementing logic of level three. The reductions afford the 
following expressions for functions OR_8_l, OR_8_2, OR_8_3, OR_8_4, OR_^8_5, 
OR_8_6, OR_8_7, and OR_8_8, 

OR_8_l = [OR_4_l], v [OR_4_l] 2 , 
OR_8_2 = ([OR_4_l], A [OR_4_l] 2 ) v ([OR_4_2], v [OR_4_2] 2 ), 
OR_8_3 = [([OR_4_l]i A [OR_4_l] 2 ) A 
([OR_4_2], v [OR_4_2] 2 )] v [OR_4_3], v [OR_4_3] 2 , 
OR_8_4 = [([OR_4_l], A [OR_4_l] 2 ) A ([OR_4_3]i v [OR_4_3] 2 )] v 

([OR_4_2], A [OR_4_2] 2 ) v [OR_4_4], v [OR_4_4] 2 , 
OR_8_5 = [([OR_4_l] 1 A [OR_4_l] 2 ) A ([OR_4_4], v [OR_4_4] 2 )] v 

[([OR_4_2]i A [OR_4_2] 2 ) A ([OR_4_3], v [OR_4_3] 2 )] , 
OR_8_6 = [([OR_4_2], A [OR_4_2] 2 ) A ([OR_4_4], v [OR_4_4] 2 )] v 
([OR_4_3], A [OR_4_3] 2 ), 
OR_8_7 = ([OR_4_3] , A [OR_4_3] 2 ) A 

([OR_4_4], v [OR_4_4] 2 ), 
OR_8_8 = [OR_4_4] : A [OR_4_4] 2 . 

Block 4 is a circuit implementing logic for level 4. The implementation of functions 
OR_l 6_8, OR_l 6_4, and OR_l 6_12 follows reduced formulas, 
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OR_16_4 = [([OR_8_l], A [OR_8_l] 2 ) A ([OR_8_3]j v [OR_8_3] 2 )] v 

([OR_8_2], A [OR_8_2] 2 ) v [OR_8_4], v [OR_8_4] 2 , 
OR_16_8 = [([OR_8_l], A [OR_8_l] 2 ) A ([OR_8_7], v [OR_8_7] 2 )] v 
[([OR_8_2]i A [OR_8_2] 2 ) A ([OR_8_6], v [OR_8_6] 2 )] v 
[([OR_8_3], A [OR_8_3] 2 ) A ([OR_8_5], v [OR_8_5] 2 )] v 
([OR_8_4], A [OR_8_4] 2 ) v [OR_8_8], v [OR_8_8] 2 , 
OR_16_12 = [([OR_8_4], A [OR_8_4] 2 ) A ([OR_8_8], v [OR_8_8] 2 )] v 
([OR_8_6], A [OR_8_6] 2 ) v [([OR_8_5]i A [OR_8_5] 2 ) A ([OR_8_7], v [OR_8_7] 2 )] . 

The binary tree principle of this embodiment of the present invention can be 
implemented using either OR or EXOR symmetric functions. When using EXOR 
symmetric functions there is a reduction in logic which applies. Assume that k= Zi e s2' 
where S is a set of natural numbers uniquely determined by k as a set of positions of 
ones in the binary representation of k. Then 

EXOR_n_k = ANDj e s EXOR,^'. 
Thus, designing a circuit computing EXOR_n_k 5 one gets away with computing only 
functions EXOR_n_2' on subsets and thus although EXOR logic is slower, there is less 
fan-out than when using OR logic. 

As can be seen in figure 21 , the most efficient circuit can comprise a mixture of OR and 
EXOR symmetric function logic circuits. 

Further reductions can be applied to logic for a parallel counter based on OR elementary 
symmetric functions. For instance, the third significant bit admits the expression 
S,_ 2 = OR_n_(2 , +2 t - , +2 t " 2 ) v [-.ORjaX^'" 1 ) a OR^^M^ 1 ' 2 )] v 
[-.OR^^ a OR_n_(2 t - , +2 t * 2 )] v [- n OR_n_2 t -' a OR_n_2 1 - 2 ]. 

The reduction can be stated more generally using the expression: 

Sk = {OR_n_2 k a -.OR_n_2 k+1 } v {OR_n_2 k+, + 2 k a -nOR_n_2 k+2 } 
v {OR_n_2 k+2 + 2 k a ^OR_n_2 k+2 +2 k+l } 



v OR n 2*+ 2 t_1 + 2 t_2 +2 k 
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where Sk is the k 01 binary output, k=0 to t-1 and t is the number of outputs. 

The generation of an output bit below the most significant bit can be explained as 
at least one AND combination of the output of one symmetric function with an 
inverted output of another symmetric function and OR combining the result of 
the AND combinations. 

Another important application of reductions is logic for a conditional parallel counter. A 
conditional parallel counter is a module with n inputs. Let Q be a subset of {0,1 ...n}. 
The subset determines a condition. The module produces the binary representation of 
the number of high inputs if this number of high inputs belongs to Q. If the number of 
high inputs does not belong to Q, the outputs can be any logical function. Such a 
module can replace a parallel counter if the number of high inputs is in Q. 

A useful conditional parallel counter has Q={0,1 . . .m} for some m<n. Logic for such a 
counter can be obtained from logic for a parallel counter with m inputs by replacing 
every OR_m_k with OR_nJk. For instance, if Q={0,1,2,3} then a conditional parallel 
counter has 2 outputs Si, So given by 

S , = OR_n_2, S 0 = EXOR_n_l . 
Another instance of a conditional parallel counter has Q={ 0,1,2,3,4,5}, 

S 2 = OR_n_4 5 Si = -iOR_n_4 a OR_n_2, S 0 = EXOR_n_l . 
If the number of high inputs for one of these two counters does not belong to Q then the 
output is the binary representation of the greatest element of Q, i.e., 3=1 1 or 5=101. 

Although the previously described embodiment comprises a binary tree hierarchical 
arrangement of logic units, the present invention is applicable to any hierarchical 
arrangement of logic units. The splitting of the inputs need not be on a binary basis and 
all inputs need not be input to logic units for performing small elementary symmetric 
functions. 

For example, figure 22 illustrates a hierarchical arrangement in which only four of the 
inputs are input to elementary logic units. Four of the inputs are only input into a logic 
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unit at the third level of the hierarchy. Each logic unit at each level of the hierarchy 
comprises the logic of logic units at preceding levels. In this example, the logic units at 
level 2 on the left comprise the logic of two logic units at the first level and the logic 
unit at level 3 on the left comprises two of the logic units at the second level. The logic 
unit at the third level on the right is not formed of sub units of logic in this embodiment. 
The logic unit at the fourth level comprises all of the logic units and comprises the logic 
circuit. 

Figure 23 is another example illustrating the division of the logic circuit of figure 12 
into two hierarchical levels. In this example, one logic unit at the first level has five 
inputs and the other has two. The logic unit having five inputs comprises the logic for 
performing the OR_5_l, OR_5_2, OR__5_3 , OR_5_4 and OR 5 5 symmetric functions 
as can be seen in figure 12. The logic unit having two inputs comprises the logic for 
performing the EXOR_7_l symmetric function as can be seen in figure 12. The logic 
unit at the second level comprises the logic units at the first level and comprises the 
complete logic circuit. 

Figure 24 is a further example illustrating the division of the logic circuit of figure 13 
into two hierarchical levels. In this example, one logic unit at the first level has four 
inputs and the other has three. The logic unit having four inputs comprises the logic for 
performing the OR_4_l, OR_4 2, OR_4_3 and OR_4_4 symmetric functions as can be 
seen in figure 13. The logic unit having three inputs comprises the logic for performing 
the OR_3_l, OR_3_2 and OR_3 3 symmetric functions as can be seen in figure 13. 
The logic unit at the second level comprises the logic units at the first level and 
comprises the complete logic circuit. 

During the design of the parallel counter it is possible to save logic by reusing fast logic 
units already available. There is a useful formula, 

OR_nJc(Xi...X n ) = -,OR_n_(n+l.k)(-,X 1 ...- l X n ). 
Thus if a library contains a fast module generating OR_4_3 then this module can be 
used with inverters to generate OR_4_2. The opposite observation holds as well: an 
OR_4_2 module enables the generation of OR_4 3. 
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An embodiment that implements a transistor economical and high-speed realisation of 
threshold functions will now be described with reference to figures 25 to 28. In this 
embodiment the threshold functions are implemented as elementary symmetric 
functions. 

It is generally known in electronics that AND-OR-INVERT gates are both economical 
in terms of the number of transistors to realize them and have good delay properties. 
Therefore this embodiment of the present invention utilises this to provide an 
economical and high-speed circuit design. 

As described above, it is known that : 

OR_n_k(Xi...X n ) = -iOR.nJn+l-k)(-iX,...-iX n ) 

This leads to: 

iOR_n_k(X,...X n ) = OR_n_(n+l-kX-iXi...-nX n ). 

and 

OR_n_k(-iX,... ^X n ) = OR_nJn+l-k)(Xi...X n ).. 

To simplify notation, equation (a) can be written as: 

[n,k] = [ n,n+l-k r 

Equation (b) can be written as: 

[n,k]' = [ mn+l-kl 

Equation (c) can be written as: 

[nJd = [n,n+l-k]' 

where * denotes an inversion of the outputs and denotes inverted inputs. 

Using these relationships, the circuit for the elementary symmetric function OR_8_4 
[8,4] can be constructed in a similar manner to the embodiment described hereinabove 
with reference to figure 14. Figure 25 illustrates the binary tree implementation of the 
elementary symmetric function OR84 in which there are three levels of logic. The 
circuit receives inverted inputs XV . . .X8\ The logic units in the first layer comprise a 
NAND gate and NOR-gate as shown in figure 26. If the inputs to this logic unit are A' 
and B\ where 6 denotes the inverse, the outputs of this block are [2*1] = (A'aB')* and 



•(a) 
..(b) 
..(c) 
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[2,2] = (AVB7 respectively. This logic circuit receives inverted inputs and implements 
an elementary symmetric function. 

At the second level the outputs [2,l]a, [2,2]a, [2,l]b, [2,2]b from two consecutive first 

layer logic units are combined to derive the outputs £4JJ, £4^2], [43] and \4A] , To do 

this the following relationships are used: 

14,41 = [4,1]' = ([2,l]a+[2,l]b)' 

[43] = [4,2]' = ([2,l]a [2,l]b + [2,2]a + [2,2]b)' 

[4.2] = [4,3]' = <[2,l]a [2,2]b + [2,2]a [2,l]b)' 

£4ja=[4 9 4]' = ([2,2]a[2^]b)' 

The logic circuit realizing these logic equations is shown in figure 27. This logic circuit 
receives non inverted inputs and implements the inverted elementary symmetric 
function. 

At the third level the outputs folia, [4.21a , [4.31a. fo41a. [4.11b. [4.2]b , fo31b and 
[4.41b from two consecutive second layer logic units are combined to derive the output 
[8,4], 

The following relationship is used: 

[8,4]= [8.5V « r4.11ar4.41bH-r4.21ar4.31b+r4.31ar4.21b+fo41ar4.11b 

The logic circuit realizing these logic equations is shown in figure 28. This logic circuit 

receives inverted inputs and implements an elementary symmetric function. 

It can thus be seen from figures 25 to 29 that symmetric functions and inverted 
symmetric functions are implemented at alternate levels of the hierarchical arrangement 
of logic units. If there are an odd number of levels, the inputs to the circuit must be 
inverted, as is the case for the illustrated example [8,4]. This use of inverted symmetric 
functions enables faster NAND gates to be used instead of AND gates (it should be 
noted that AND gates are implemented as a NAND gate with an inverter and thus the 
use of a NAND gate instead of an AND gate reduces the logic required to implement 
the function). The reduction of logic required also reduces the area of the logic circuit. 
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In this embodiment of the present invention, each level of the hierarchical logic 
structure includes inversion logic. 

Although this technique has been illustrated with respect to the function [8,4], it will be 
apparent to a skilled person that the technique can be applied to any size function. 
Further, although this embodiment of the present invention has been implemented as a 
binary tree structure, the technique can be used for any hierarchical structure of logic 
units. Also, although in this embodiment of the present invention inverted inputs are 
used, if the number of levels of logic units in the hierarchy is even, the inputs need not 
be inverted. Instead inverted symmetric functions at an even number of levels can be 
used. Inverted inputs are required for circuits having an odd number of levels 
performing inverted symmetric functions. . 

An important application of conditional parallel counters is constant multipliers. A 
constant multiplier is a module whose inputs form binary representations of two 
numbers A, B, and outputs comprise the binary representation of the product A*B 
whenever A is a number that belongs to a set of allowed constants. Since constant 
multipliers are smaller and faster then multipliers, it is beneficial to use them whenever 
one can choose one multiplicand from the set of allowed constants. One can do it, for 
instance, designing a digital filter. 

Another aspect of the present invention comprises a technique for multiplication and 
this will be described hereinafter. 

Multiplication is a fundamental operation in digital circuits. Given two n-digit binary 
numbers 

A n .i2 n - l +A IJ . 2 2 n ' 2 +...-hA,2-l-Ao and B n . I 2 n " I +B n . 2 2 n - 2 +...+Bi2+B 0 , 
their product 

P 2n .i2 2n " 1 +P 2n . 2 2 2n - 2 +. . .+P,2+P 0 
has up to 2n digits. Logical circuits generating all P s as outputs generally follow the 
scheme in figure 14. Wallace has invented the first fast architecture for a multiplier, 
now called the Wallace-tree multiplier (Wallace, C. S., A Suggestion for a Fast 
Multiplier, IEEE Trans. Electron. Comput. EC-13: 14-17 (1964))(the content of which 
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is hereby incorporated by reference). Dadda has investigated bit behaviour in a 
multiplier (L. Dadda, Some Schemes for Parallel Multipliers, Alta Freq 34: 349-356 
(1965)) (the content of which is hereby incorporated by reference). He has constructed a 
variety of multipliers and most multipliers follow Dadda's scheme. 

Dadda' s multiplier uses the scheme in on figure 29. If inputs have 8 bits then 64 parallel 
AND gates generate an array shown in figure 30. The AND gate sign a is omitted for 
clarity so that A\ aBj becomes AjBj. The rest of figure 30 illustrates array reduction that 
involves full adders (FA) and half adders (HA). Bits from the same column are added 
by half adders or full adders. Some groups of bits fed into a full adder are in rectangles. 
Some groups of bits fed into a half adder are in ovals. The result of array reduction is 
just two binary numbers to be added at the last step. One adds these two numbers by 
one of fast addition schemes, for instance, conditional adder or carry-look-ahead adder. 

This aspect of the present invention comprises two preferred steps: array deformation 
and array reduction using the parallel counter in accordance with the first aspect of the 
present invention. 

The process of array deformation will now be described. 

Some parts of the multiplication array, formed by AjBj such as on figure 30, have 
interesting properties. One can write simple formulas for the sum of the bits in these 
parts. Examples of such special parts are on figure 31. In general, chose an integer k, 
and those AjBj in the array such that the absolute value of i-j-k is less or equal to 1 
comprise a special part 

Let Sj be the bits of the sum of all the bits of the form AiBj shown on figure 1 . Then 

So = Ao a Bo, 
Si = (Ai a B 0 ) © (A 0 a BO, 
S 2 = (Ai a BO © (Ai a B i a Ao a Bo), 
S 2 k+i = (Ak+i a B k ) © (At a B k+ 0 © (A k a B k a A k .t a B k _0 

forallk>0, 
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S 2k "= (A k a B k ) © (A k .i a B k ., a • * 

((A k+ i a B k+ i) v (A k -i a B k .i a (A k+I v B k+ i))) 
for allk>l. 

These formulas show that the logic for summing the chosen entries in the array does not 
get large. Whereas if random numbers were summed the logic for the (n 4- l) th bit is 
larger than the logic for the n 1 * 1 bit. 

Using these formulas, one can generate a different array. The shape of array changes! 
This is why it is called array deformation. These formulas are important because one 
can speed up a multiplication circuit by generating an array of a particular shape. 

The array in figure 32 is for ah 8-bit multiplication. The AND gate sign a is omitted for 
clarity so that Aj aBj becomes AjBj. Array deformation logic generates X, Y, and Z: 

X = (A, a B 6 ) 0 (A 0 a B 7 ), 

Y = A, a B 7 a -,(A 0 a B 6 ), 

Z = A] A B7 A Ao A B6. 

The advantage of this array over one in figure 30 is that the maximal number of bits in a 
column is smaller. The array in figure 30 has a column with 8 bits. The array on figure 
32 has 4 columns with 7 bits but none with 8 or more bits. The logic for the generation 
of X Y and Z is illustrated in figure 33. This logic can be used in parallel with the first 
two full adders (illustrated in Figure 2) in the array reduction step thus avoiding delays 
caused by additional logic. 

Array reduction is illustrated in figure 32. The first step utilizes 1 half adder, 3 full 
adders, 1 parallel counter with 4 inputs, 2 parallel counters with 5 inputs, 1 parallel 
counter with 6 inputs, and 4 parallel counters with 7 inputs. The three parallel counters 
(in columns 7, 8, and 9) have an implementation based on 7=5+2 partition. The bits X, 
Y, and Z join the group of two in the partition. The counter in column 6 is implemented 
on 7=4+3 partition. The counter in column 5 is based on 6=3+3 partition. The remaining 
counters should not be partitioned. The locations of full adders are indicated by ovals. 
The half adder is shown by a rectangle. 
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An adder for adding the final two binary numbers is designed based on arrival time of 
bits in two numbers. This gives a slight advantage but it is based on common 
knowledge, that is conditional adder and ripple-carry adder. 

Although in this embodiment the addition of two 8 bit numbers has been illustrated, the 
invention is applicable to any N bit binary number addition. For example for 16 bit 
addition, the array reduction will reduce the middle column height from 16 to 15 thus 
allowing two seven bit full adders to be used for the first layer to generate two 3 bit 
outputs and the left over input can be used with the other two 3 outputs as an input to a 
further seven input full adder thus allowing the addition of the 16 bits in only two 
layers. 

Although this embodiment of the present invention has been described with reference to 
the formation of the array by logical AND binary combination, this aspect of the present 
invention encompasses any method of forming the array including any method of 
logically combining bits of two binary numbers e.g. OR combining, EXOR combining 
and NAND combining and forming the array using Booth encoding. Further, the length 
of the two binary numbers need not be the same. 

Although this aspect of present invention has been described with reference to a specific 
multiplication logic circuit, the present invention also applies to any logic circuit that 
performs multiplication including a multiply-accumulate logic circuit (which can be 
viewed as a special case of a multiplication logic circuit). In a multiply-accumulate 
logic circuit the operation AxB+C is implemented where C is the accumulation of 
previous multiplications. The multiply-accumulate logic circuit operates by generating 
the array of AxB as described hereinabove for the multiplication logic circuit. An 
additional row is added in the array for the bits of C. C can have many more bits than A 
or B due to previous accumulations. This enlarged array then undergoes array reduction 
as described hereinabove. 

This aspect of the present invention can be used with the parallel counter of the first 
aspects of the present invention to provide a fast circuit. 
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The parallel counter of the first aspects of the present invention has other applications, 
other than used in the multiplier of one aspect of the present invention. It can be used in 
RSA and reduced area multipliers. Sometimes, it is practical to build just a fragment of 
the multiplier. This can happen when the array is too large, for instance in RSA 
algorithms where multiplicands may have more than more than 1 000 bits. This 
fragment of a multiplier is then used repeatedly to reduce the array. In current 
implementations, it consists of a collection of full adders. One can use 7 input parallel 
counters followed by full adders instead. 

A parallel counter can also be used in circuits for error correction codes. One can use a 
parallel counter to produce Hamming distance. This distance is useful in digital 
communication. In particular the Hamming distance has to be computed in certain 
types of decoders, for instance, the Viterbi decoder or majority-logic decoder. 

Given two binary messages (Ai, A2, ... A n ) and (Bi, B2, ... B n )» the Hamming distance 
between them is the number of indices i between 1 and n such that Aj and Bi are 
different This distance can be computed by a parallel counter whose n inputs are 

(Ai © Bi, A 2 © B 2 , ... A n © B„). 

The multiply-and-add operation is fundamental in digital electronics because it includes 
filtering. Given 2n binary numbers Xj, X2, ... X n , Yi, Y2, ... Y n , the result of this 
operation is 

X,Y 1 + X2Y 2 H-... + X n Y n . 
One can use the multiplier described to implement multiply-and-add in hardware. 
Another strategy can be to use the scheme in figure 29. All partial products in products 
XjYj generate an array. Then one uses the parallel counter X to reduce the array. 

In the present invention, one can use the parallel counter whenever there is a need to 
add an array of numbers. For instance, multiplying negative number in two-complement 
form, one generates a different array by either Booth recording (A. D. Booth, A Signed 
Binary Multiplication Technique, Q. J. Mech. Appl. Math. 4: 236-240 (1951)) (the 
content of which is hereby incorporated by reference) or another method. To obtain a 
product one adds this array of numbers. 
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Figure 34 illustrates an embodiment of another aspect of the present invention. This 
embodiment generates an output in accordance with a threshold function having a 
threshold of 2 and implemented as a binary tree. The circuit thus implements an 
elementary symmetric function for the generation of the output when the number of 
input that are high (k) is at least 2. 

The output is thus generated as the OR symmetric function: 

OR_4_2 = X,aX 2 v XiaX 3 v Xj/OQ v X 2 aX 3 v X2AX4 v X3AX4 

The circuit can thus act as a switch to provide an output when a certain number of 
inputs are high. The output can comprise any elementary symmetric function e.g. 
OR_nJk where n is the number of inputs and k is the number of high inputs. 

Although in this embodiment only one output is shown, the principles of this aspect of 
the present invention can be used to generate more than one output each being OR_n__k. 
For example, one output could be OR_4_2 and another OR_4_3. Thus the present 
invention encompasses logic circuits that provide outputs using threshold functions. 
This can be used for parallel counter outputs or for other logic circuits. 

Although the present invention has been described hereinabove with reference t specific 
embodiments, it will be apparent to a skilled person in the art that modifications lie 
within the spirit and scope of the present invention. 

The logic circuits of the embodiments of the present invention described hereinabove 
can be implemented in an integrated circuit, or in any digital electronic device. 
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CLAIMS: 

1. . A parallel counter comprising: 

a plurality of inputs for receiving a binary number as a plurality of binary inputs; 

a plurality of outputs for outputting binary code indicating the number of binary 
ones in the plurality of binary inputs; and 

a logic circuit connected between the plurality of inputs and the plurality of 
binary outputs and for generating each of the plurality of binary outputs as an 
elementary symmetric function of the binary inputs. 

2. A parallel counter according to claim 1, wherein said logic circuit is arranged to 
generate at least one of the binary outputs as an elementary symmetric function of the 
binary inputs using exclusive OR logic for combining a plurality of sets of one or more 
binary inputs. 

3. . A parallel counter according to claim 2, wherein said logic circuit is arranged to 
logically AND members of each set of binary inputs and to logically exclusively OR the 
result of the AND operations. 

4. A parallel counter according to claim 3, wherein said logic circuit is arranged to 
logically AND 2 1 of the binary inputs in each set for the generation of the I th binary 
output, where i is an integer from 1 to N, N is the number of binary outputs and i 
represents the significance of each binary output, each set being unique and the sets 
covering all possible combinations of binary inputs. 

5. A parallel counter according to claim 3, wherein said logic circuit is arranged to 
logically AND members of each set of binary inputs, where each set is unique and the 
sets cover all possible combinations of binary inputs. 

6. A parallel counter according to any preceding claim, wherein said logic circuit is 
arranged to generate at least one of the binary outputs as an elementary symmetric 
function of the binary inputs using OR logic for combining a plurality of sets of one or 
more binary inputs. 
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7. A parallel counter according to claim 6, wherein said logic circuit is arranged to 
logically AND members of each set of binary inputs and to logically OR the result of 
the AND operations. 

8. A parallel counter according to claim 7, wherein said logic circuit is arranged to 
logically AND 2 N " ! of the binary inputs in each set for the generation of the N* binary 
output, where N is the number of binary outputs and the N^ binary output is the most 
significant, each set being unique and the sets covering all possible combinations of 
binary inputs. 

9. A parallel counter according to claim 7, wherein said logic circuit is arranged to 
logically AND members of each set of binary inputs, where each set is unique and the 
sets cover all possible combinations of binary inputs. 

10. A parallel counter according to claim 1, wherein said logic circuit is arranged to 
generate a first binary output as an elementary symmetric function of the binary inputs 
using exclusive OR logic for combining a plurality of sets of one or more binary inputs, 
and to generate an N* 11 binary output as an elementary symmetric function of the binary 
inputs using OR logic for combining a plurality of sets of one or more binary inputs. 

11. A parallel counter according to any preceding claim, wherein said logic circuit is 
arranged to generate two possible binary outputs for a binary output less significant than 
the N* binary output, as elementary symmetric functions of the binary inputs using OR 
logic for combining a plurality of sets of one or more binary inputs where N is the 
number of binary outputs, the sets used for each possible binary output being of two 
different sizes which are a function of the binary output being generated; and said logic 
circuit include selector logic to select one of the possible binary outputs based on a 
more significant binary output value. 

12. A parallel counter according to claim 1 1, wherein said logic circuit is arranged 
to generate the two possible binary outputs for the (N-l)* binary output less significant 
than the N m binary output, as elementary symmetric functions of the binary inputs using 



021 2995 A2 I > 



WO 02/12995 



PCT/GB01/03415 



40 

OR logic for combining a plurality of sets of one or more binary inputs, the sets used for 
each possible binary output being of size 2 N * ! + 2 N * 2 and 2 N " 2 respectively and said 
selector logic being arranged to select one of the possible binary outputs based on the 
N 1 * 1 binary output value. 

13. A parallel counter according to any one of claims 1 to 10, wherein said logic 
circuit is arranged to generate two possible binary outputs for a binary output less 
significant than the binary output, as elementary symmetric functions of the binary 
inputs; and said logic circuit includes selector logic to select one of the possible binary 
outputs based on a more significant binary output value. 

,14. A parallel counter according to any one of claims 1 to 10, wherein said logic 
circuit includes logic units for generating intermediate outputs as elementary symmetric 
functions of the binary inputs and is arranged to generate a binary output less significant 
than the N 01 binary output by combining intermediate outputs of the logic units by AND 
combining at least the . intermediate output of one logic unit and an inverted output of 
another logic unit and OR combining the result of the AND combining with another 
intermediate output. 

15. A parallel counter according to claim 14, wherein said logic circuit is arranged 
to generate the binary output S k , where k=0 to t-1 and t is the number of 
outputs in accordance with the relationship: 

Sk = {OR_n_2 k a -,OR_n_2 k+I } v {OR_n_2 k+1 + 2 k a -nOR_n_2 k+2 } 
v {OR.n_2 k+2 +2 k A^OR_n_2 k+2 +2 k+1 } 

' ' ' vOR - n_2 t +2 M +2 t - 2 +2 k " 

where a is the logical AND operation, v is the logical OR operation, and i is an 
inversion operation. 

16. A parallel counter according to any preceding claim, wherein said logic circuit 
includes a plurality of subcircuit logic modules each generating intermediate binary 



BNSDOCID: <WO 021 2995 A2 1 > 



WO 02/12995 



PCT/GBO 1/034 15 



41 

outputs as an elementary symmetric function of some of the binary inputs, and logic for 
logically combining the intermediate binary outputs to generate said binary outputs. 

17. . A parallel counter according to claim 16, wherein said subcircuit logic modules 
are arranged to use OR logic for combining sets of said some of said binary inputs. 

18. A parallel counter according to claim 17, wherein said logic circuit includes one 
or more logic modules each for generating a binary output as an elementary symmetric 
function of the binary inputs using executive OR logic for combining a plurality of sets 
of one or more binary inputs. 

19. A parallel counter according to any one of claims 1 to 14, wherein said logic 
circuit implements a large elementary symmetric function by implementing a plurality 
of small elementary symmetric functions and combining the results. 

20. A parallel counter according to any preceding claim, wherein said logic circuit is 
divided into a plurality of logic units, each logic unit is arranged to generate logic unit 
binary outputs as an elementary symmetric function of the binary inputs to the logic 
unit, the binary inputs of said plurality of inputs are divided into inputs into a plurality 
of said logic units, and the binary outputs of said plurality of outputs are generated 
using binary outputs of a plurality of said logic units. 

21 . A parallel counter according to claim 20, wherein the logic units are arranged 
hierarchically such that logic units at a higher level in the hierarchy include the logic of 
at least one logic unit at a lower level in the hierarchy and have more of the binary 
inputs as inputs than the logic units at a lower level in the hierarchy 

22. A parallel counter according to claim 20 or 21, wherein the binary inputs of said 
plurality of inputs are divided according to a binary tree into inputs into a plurality of 
said logic units. 

23. A parallel counter according to claim 22, wherein said logic units are arranged to 
receive 2 n of said binary inputs, where n is an integer indicating the level of the logic 
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units in the binary tree, said logic circuit has m logic units at each level, where m is a 
rounded up integer determined from (the number of binary inputs)/ 2 n , logic units 
having a higher level in the binary tree comprise logic of logic units at lower levels in 
the binary tree, and each logic unit is arranged to generate logic unit binary outputs as a 
symmetric function of the binary inputs to the logic unit. 

24. A parallel counter according to claim 23, wherein each logic unit at the first 
level is arranged to generate logic unit binary outputs as a small elementary symmetric 
function of the binary inputs to said logic circuit. 

25. A parallel counter according to claim 23 or claim 24, wherein each logic unit at 
the first level is arranged to generate logic unit binary outputs as an elementary 
symmetric function of the binary inputs to said logic circuit using OR logic for 
combining the binary inputs. 

26. A parallel counter according to claim 25, wherein each logic unit at the first, 
level is arranged to logically AND each of the binary inputs to the logic unit and to 
logically OR each of the binary inputs to the logic unit to generate the logic unit binary 
outputs. 

27. A parallel counter according to claim 24, wherein each logic unit at the first 
level is arranged to generate logic unit binary outputs as an elementary symmetric 
function of the binary inputs to said logic circuit using exclusive OR logic for 
combining the binary inputs. 

28. A parallel counter according to claim 27, wherein each logic unit at the first 
level is arranged to logically AND each of the binary inputs to the logic unit and to 
logically exclusively OR each of the binary inputs to the logic unit to generate the logic 
unit binary outputs. 

29. A parallel counter according to any one of claims 23 to 28, wherein elementary 
logic units are provided as the logic units at the first level for performing elementary 
symmetric functions, outputs from each of two primary elementary logic units receiving 
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four logically adjacent binary inputs from said plurality of inputs are input to two 
secondary elementary logic units, an output from each of the secondary elementary 
logic units is input to a tertiary elementary logic unit, and said primary, secondary and 
tertiary elementary logic units form a secondary logic unit at a second level of the 
binary tree having a binary output comprising a binary output from each of said 
secondary elementary logic units and two binary outputs from said tertiary elementary 
logic unit. 

30. A parallel counter according to claim 29, wherein tertiary logic units at a third 
level of the binary tree each comprise two secondary logic units receiving eight 
logically adjacent binary inputs from said plurality of inputs, four elementary logic units 
receiving as inputs the outputs of said two secondary logic units, and further logic for 
generating binary outputs as a symmetric function of the binary inputs to said tertiary 
logic unit using the binary outputs of said four elementary logic units. 

3 L A parallel counter according to claim 30, wherein quaternary logic units at a 
fourth level of the binary tree each comprise two tertiary logic units receiving sixteen 
logically adjacent binary inputs from said plurality of inputs, four elementary logic units 
receiving as inputs the outputs of said two tertiary logic units, and further logic for 
generating binary outputs as a symmetric function of the binary inputs to said 
quaternary logic unit using the binary outputs of said four elementary logic units 

32. A parallel counter according to any one of claims 23 to 28, wherein elementary 
logic units are provided as the logic units at the first level for performing elementary 
symmetric functions, and logic units for higher levels are comprised of logic units of 
lower levels. 

33. A parallel counter according to claim 32, wherein said logic units for higher 
levels above the second level comprise logic units of an immediately preceding level 
and elementary logic units. 

34. A parallel counter according to any one of claims 23 to 33, wherein each logic 
unit at each level is arranged to generate logic unit binary outputs as an elementary 
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symmetric function of the binary inputs to said logic circuit using OR logic for 
combining the binary inputs. 

35. A parallel counter according to any one of claims 23 to 33, wherein each logic 
unit at each level is arranged to generate logic unit binary outputs as an elementary t 
symmetric function of the binary inputs to said logic circuit using exclusive OR logic 
for combining the binary inputs. 

36. A parallel counter according to any one of claims 20 to 35, wherein the logic 
units are arranged hierarchically and at least one logic unit in at least one level of the 
hierarchy implements an inverted elementary symmetric function. 

37. .A parallel counter according to claim 36, wherein logic units at an odd number 
of levels in the hierarchy implement inverted elementary symmetric functions, logic 
units at an ev^n number of levels in the hierarchy implement symmetric functions, and 
the inputs to the logic units at the first level of the hierarchy are inverted. 

38. A parallel counter according to claim 36, wherein logic units at an even number 
of levels in the hierarchy implement inverted elementary symmetric functions, logic 
units at an even number of levels in the hierarchy implement symmetric functions, and 
the inputs to the logic units at the first level of the hierarchy are input to logic units in a 
first level in the hierarchy uninverted. 

39. A parallel counter according to claim 36, wherein logic units at an even number 
of levels in the hierarchy implement inverted elementary symmetric functions, logic - 
units at an odd number of levels in the hierarchy implement symmetric functions, and 
the inputs to the logic units at the first level of the hierarchy are inverted. 

40. A parallel counter according to claim 36, wherein at least one logic unit in at 
least one level of the hierarchy implements an elementary symmetric function and the or 
each inverted elementary symmetric function and the or each elementary symmetric 
function are implemented in alternated levels in the hierarchy. ... 
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41 . A parallel counter according to any one of claims 36 to 40, wherein logic units 
in at least one level in the hierarchy comprise inversion logic. 

42. A parallel counter according to any one of claims 36 to 41 , wherein the logic 
units are arranged hierarchically in a binary tree structure. 

43. A parallel counter according to any preceding claim, wherein the number of 
inputs is at least four and the number of outputs is at least three. 

44. A parallel counter comprising: 

at least five inputs for receiving a binary number as a plurality of binary inputs; 

at least three outputs for outputting binary code indicating the number of binary 
ones in the plurality of binary inputs; and 

a logic circuit connected between the plurality of inputs and the plurality of 
binary outputs and for generating each of the plurality of binary outputs as an 
elementary symmetric function of the binary inputs. 

45. A parallel counter according to claim 44, wherein said logic circuit is arranged 
to generate at least two outputs independently of each other. 

46. A parallel counter comprising: 

n inputs for receiving a binary number as binary inputs, where 4>n>7; 

three outputs for outputting binary code indicating the number of binary ones in 
the binary inputs; and 

a logic circuit connected between the inputs and the three outputs and for 
generating a first output as an elementary symmetric function EXOR_n_l of the binary 
inputs, a second output as a combination of three elementary symmetric functions 
OR_n_2, OR_n_4 and OR_n_6, and a third output as an elementary symmetric function 
OR_n_4. 

47. A parallel counter comprising: 

n inputs for receiving a binary number as binary inputs, where 8>n>15; 
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four outputs for outputting binary code indicating the number of binary ones in 
the binary inputs; and 

a logic circuit connected between the inputs and the four outputs and for 
generating a first output as an elementary symmetric function EXOR_n_l of the binary 
inputs, a second output as an elementary symmetric function EXOR_n_2 of the binary 
inputs, a third output as a combination of three elementary symmetric functions 
OR_n_4_, OR_n_8 and OR_n_12, and a third output as an elementary symmetric 
function OR_n_8. 

48. A conditional parallel counter having m possible high inputs out of n inputs, 
where m<n, and n and m are integers, the conditional parallel counter comprising the 
parallel counter according to any preceding claim for counting inputs to generate p 
outputs for m inputs, wherein the number n of inputs to the counter is greater than 2 P . 

49. A constant multiplier comprising the conditional parallel counter according to 
claim 48. 

50. A digital filter comprising a constant multiplier according to claim 48. 

51. A logic circuit including the parallel counter according to any one of claims 1 to 
48. 

52. An integrated circuit including the parallel counter according to any one of 
claims 1 to 48. . 

53. A digital electronic device including the parallel counter according to any one of 
claims 1 to 48. 

54. A logic circuit for multiplying two binary numbers comprising: 

array generation logic for generating an array of binary numbers comprising 
combinations of each bit of each binary number; 

array reduction logic including at least one parallel counter.according to any one 
of claims 1 to 48 for reducing the number of combinations in the array; and 
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binary addition logic for adding the reduced combinations to generate an output. 

55. A logic circuit for multiplying two binary numbers, the logic circuit comprising: 
array generation logic for generating, from the two binary numbers, an array of 

binary values which are required to be added, and for further logically combining binary 
values in the array to generate the array in which the maximal depth of the array is 
below N bits, where N is the number of bits of the largest of the two binary numbers; 

array reduction logic for reducing the depth of the array to two binary numbers; 

and 

addition logic for adding the binary values of the two binary numbers. 

56. A logic circuit according to claim 55, wherein said array generation logic is 
arranged to perform a logical binary operation between each bit in one binary number 
and each bit in the other binary number to generate an array of logical binary 
combinations comprising an array of binary values. 

57. A logic circuit according to claim 56, wherein said array generation logic is 
arranged to perform a logical AND operation between each bit in one binary number 
and each bit in the other binary number to generate an array of logical AND 
combinations comprising an array of binary values. 

58. A logic circuit according to claim 57, wherein said array generation logic is 
arranged to perform the further logical combination of values for values formed by the 
logical binary combination of each bit A* of one binary number and each bit Bj of the 
other binary number, where i-j-k <1, k is a chosen integer, and i and j are integers from 
ltoN. 

59. A logic circuit according to any one of claims 55 to 58, wherein said array 
generation logic is arranged to logically AND combine each bit A* of the first binary 
number with each bit Bj of a second binary number to generate said array comprising a 
sequence of binary numbers represented by said logical AND combinations, Aj AND Bj 
and to carry out further logical combination by logically combining the combination Ai 
AND Bn-2> Ai AND B^.l where N is the number of bits in the binary numbers. 
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60. A logic circuit according to claim 59, wherein said array generation logic is 
arranged to combine the combinations Ai AND B N -2 and Ao AND B N -i, using exclusive 
OR logic to replace these combinations, and to combine Ai AND Bn-i and Ao AND B N -2 
to replace the Ai AND Bn-i combination. 

61 . A logic circuit according to any one of claims 55 to 60, wherein said array 
reduction logic includes at least one of: at least one full adder, at least one half adder, 
and at least one parallel counter. 

62. A logic circuit according to claim 61, wherein said array reduction logic 
includes at least one parallel counter according to any one of claims 1 to 40. 

63. A multiply-accumulate logic circuit comprising the logic circuit according to 
any one of claims 55 to 62, wherein said array generation logic is arranged to include an 
accumulation of previous multiplications. 

64. An integrated circuit including the logic circuit according to any one of claims 
55 to 62. 

65. A digital electronic device including the logic circuit according to any one of 
claims 55 to 62. 

66. A logic circuit comprising: 

at least four inputs for receiving a binary number as a plurality of binary inputs; 
at least one output for outputting binary code; and 

logic elements connected between the plurality of inputs and the or each binary 
output and for generating the or each binary output in accordance with a threshold 
function implemented as a binary tree and having a threshold of at least 2. 

67. A logic circuit according to claim 66, wherein the logic elements are arranged to 
generate the or each binary output as an elementary symmetric function of the binary 
inputs. 
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68. A logic circuit according to claim 67, wherein the logic elements are arranged to 
generate at least one of the binary outputs as an OR symmetric function of the binary 
inputs. 

69. A logic circuit according to claim 68, wherein the logic elements are arranged to 
generate at least one of the binary outputs as an exclusive OR symmetric function of the 
binary inputs. 

70. A logic circuit according to any one of claims 66 to 69, wherein said logic 
elements comprise a plurality of subcircuit logic modules each generating intermediate 
binary outputs as an elementary symmetric function of some of the binary inputs, and 
logic for logically combining the intermediate binary outputs to generate the or each 
binary output. 

71 . A logic circuit according to claim 67, wherein said logic elements comprise a 
plurality of logic modules each for generating intermediate binary outputs as an 
elementary symmetric function of some of the binary inputs, and logic for logically 
combining the intermediate binary outputs to generate the or each binary output, and.the 
logic modules are arranged hierarchically and at least one logic module in at least one 
level of the hierarchy implements an inverted elementary symmetric function. 

72. A logic circuit according to claim 71, wherein logic modules at an odd number 
of levels in the hierarchy implement inverted elementary symmetric functions, logic 
modules at an even number of levels in the hierarchy implement symmetric functions, 
and the inputs to the logic modules at the first level of the hierarchy are inverted. 

73. A logic circuit according to claim 71, wherein logic modules at an even number 
of levels in the hierarchy implement inverted elementary symmetric functions, logic 
modules at an even number of levels in the hierarchy implement symmetric functions, 
and the inputs to the logic modules at the first level of the hierarchy are input to logic 
units in a first level in the hierarchy uninverted. 
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74. A logic circuit according to claim 71, wherein logic modules at an even number 
of levels in the hierarchy implement inverted elementary symmetric functions, logic 
modules at an odd number of levels in the hierarchy implement symmetric functions, 
and the inputs to the logic modules at the first level of the hierarchy are inverted. 

75. A logic circuit according to claim 71, wherein at least one logic module in at 
least one level of the hierarchy implements an elementary symmetric function, and the 
or each inverted elementary symmetric function and the or each elementary symmetric 
function are implemented in alternated levels in the hierarchy. 

76. A logic circuit according to any one of claims 71 to 75, wherein logic modules 
in at least one level in the hierarchy comprise inversion logic. 

77. A logic circuit according to any one of claims 71 to 76, wherein the logic 
modules are arranged hierarchically in a binary tree structure. 

78. A logic circuit comprising: 

, at least four inputs for receiving a binary number as a plurality of binary inputs; 
at least one output for outputting binary code; and 
. .. logic elements connected between the plurality of inputs and the plurality of 
binary outputs arranged to generate the or each of the plurality of binary outputs as an 
elementary symmetric function of the binary inputs. 

79. A logic circuit according to claim 78, wherein said logic elements are arranged 
to generate at least one of the binary outputs as an elementary symmetric function of the 
binary inputs using exclusive OR logic for combining a plurality of sets of one or more 
binary inputs. 

80. A logic circuit according to claim 79, wherein said logic elements are arranged 
to logically AND members of each set of binary inputs and to logically exclusively OR 
the result of the AND operations. 
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81. A logic circuit according to claim 80, wherein said logic elements are arranged 
to logically AND 2 1 of the binary inputs in each set for the generation of the i A binary 
output, where i is an integer from 1 to N, N is the number of binary outputs and i 
represents the significance of each binary output, each set being unique and the sets 
covering all possible combinations of binary inputs. 

82. A logic circuit according to claim 80, wherein said logic elements are arranged 
to logically AND members of each set of binary inputs, where each set is unique and the 
sets cover all possible combinations of binary inputs. 

83. A logic circuit according to any one of claims 78 to 82, wherein said logic 
elements are arranged to generate at least one of the binary outputs as an elementary 
symmetric function of the binary inputs using OR logic for combining a plurality of sets 
of one or more binary inputs. 

84. A logic circuit according to claim 83, wherein said logic elements are arranged 
to logically AND members of each set of binary inputs and to logically OR the result of 
the AND operations. 

85. A logic circuit according to claim 84, wherein said logic elements are arranged 
to logically AND 2 N_I of the binary inputs in each set for the generation of the N 1 * 1 
binary output, where N is the number of binary outputs and the N th binary output is the 
most significant, each set being unique and the sets covering all possible combinations 
of binary inputs. 

86. A logic circuit according to claim 84, wherein said logic elements are arranged 
to logically AND members of each set of binary inputs, where each set is unique and the 
sets cover all possible combinations of binary inputs. 

87. A logic circuit according to claim 78, wherein said logic elements are arranged 
to generate a first binary output as an elementary symmetric function of the binary 
inputs using exclusive OR logic for combining a plurality of sets of one or more binary 
inputs, and to generate an N* binary output as an elementary symmetric function of the 
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binary inputs using OR logic for combining a plurality of sets of one or more binary 
inputs. 

88. A logic circuit according to any one of claims 78 to 87, wherein said logic 
elements are arranged to generate two possible binary outputs for a binary output less 
significant than the binary output, as elementary symmetric functions of the binary 
inputs using OR logic for combining a plurality of sets of one or more binary inputs 

, where N is the number of binary outputs, the sets used for each possible binary output 
being of two different sizes which are a function of the binary output being generated; 
and said logic elements include selector logic to select one of the possible binary 
outputs based on a more significant binary output value. 

89. A logic circuit according to claim 88, wherein said logic elements are arranged 
to generate the two possible binary outputs for the (N-l) 01 binary output less significant 
than the N** 1 binary output, as elementary symmetric functions of the binary inputs using 
OR logic for combining a plurality of sets of one or more binary inputs, the sets used for 
each possible binary output being of size 2 N_1 + 2 N " 2 and 2 N ~ 2 respectively and said 
selector logic being arranged to select one of the possible binary outputs based on the 
N 111 binary output value. 

90. A logic circuit according to any one of claims 78 to 87, wherein said logic 
elements are arranged to generate two possible binary outputs for a binary output less 
significant than the binary output, as elementary symmetric functions of the binary 
inputs; and said logic elements include selector logic to select one of the possible binary 
outputs based on a more significant binary output value. 

91. A logic circuit according to any one of claims 78 to 87, .wherein said logic 
elements include logic units for generating intermediate outputs as elementary 
symmetric functions of the binary inputs, and are arranged to generate a binary output 
less significant than the binary output by combining intermediate outputs of the 
logic units by AND combining at least the intermediate output of one logic unit and an 
inverted output of another logic unit and .OR combining the result of the AND 
combining with another intermediate output 
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92. A logic circuit according to claim 91, wherein said logic elements are arranged 
to generate the binary output S k , where k=0 to t-1 and t is the number of 
outputs in accordance with the relationship: 

S k = {OR_n_J2 k a ^OR_n_2 k+1 } v {OR_n_2 k+, + 2 k a -iOR_n_2 k+2 } 
v {OR^n_2 lc+2 +2 k A- 1 OR_n_2 l ^ 2 +2 k+1 } 

v OR_n_2 l + 2 t_1 + 2 t " 2 +2 k 
where a is the logical AND operation, v is the logical OR operation, and -i is an 
inversion operation. 

93. A logic circuit according to any one of claims 78 to 92, wherein said logic 
elements include a plurality of subcircuit logic modules each generating intermediate 
binary outputs as an elementary symmetric function of some of the binary inputs, and 
logic for logically combining the intermediate binary outputs to generate said binary 
outputs. 

94. A logic circuit according to claim 93, wherein said subcircuit logic modules are 
arranged to use OR logic for combining sets of said some of said binary inputs. 

95. A logic circuit according to claim 94, wherein said logic elements include one or 
more logic modules each for generating a binary output as an elementary symmetric 
function of the binary inputs using executive OR logic for combining a plurality of sets 
of one or more binary inputs. 

96. A logic circuit according to any one of claims 78 to 91, wherein said logic 
elements implement a large elementary symmetric function by implementing a plurality 
of small elementary symmetric functions and combining the results. 

97. A logic circuit according to any one of claims 78 to 96, wherein said logic 
elements are divided into a plurality of logic units, each logic unit is arranged to 
generate logic unit binary outputs as an elementary symmetric function of the binary 
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inputs to the logic unit, the binary inputs of said plurality of inputs are divided into 
inputs into a plurality of said logic units, and the binary outputs of said plurality of 
outputs are generated using binary outputs of a plurality of said logic units. 

98. A logic circuit according to. claim 97, wherein the logic units are arranged 
hierarchically such that logic units at a higher level in the hierarchy include the logic of 
at least one logic unit at a lower level in the hierarchy and have more of the binary 
inputs as inputs than the logic units at a lower level in the hierarchy 

99. A logic circuit according to claim 97 or 98, wherein the binary inputs of said 
plurality of inputs are divided according to a binary tree into inputs into a plurality of 
said logic units. 

100. A logic circuit according to claim 99, wherein said logic units are arranged to 
receive 2 n of said binary inputs, where n is an integer indicating the level of the logic 
units in the binary tree, said logic circuit has m logic units at each level, where m is a 
rounded up integer determined from (the number of binary inputs)/ 2 n , logic units 
having a higher level in the binary tree comprise logic of logic units at lower levels in 
the binary tree, and each logic unit is arranged to generate logic unit binary outputs as a 
symmetric function of the binary inputs to the logic unit. 

101. A logic circuit according to claim 100, wherein each logic unit at the first level 
is arranged to generate logic unit binary outputs as a small elementary symmetric 
function of the binary inputs to said logic circuit. 

102. A logic circuit according to claim 100 or claim 101, wherein each logic unit at 
the first level is arranged to generate logic unit binary outputs as an elementary 
symmetric function of the binary inputs to said logic circuit using OR logic for 
combining the binary inputs. 

103. A logic circuit according to claim 102, wherein each logic unit at the first level 
is arranged to logically AND each of the binary inputs to the logic unit and to logically 
OR each of the binary inputs to the logic unit to generate the logic unit binary outputs. 
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104. A logic circuit according to claim 101, wherein each logic unit at the first level 
is arranged to generate logic unit binary outputs as an elementary symmetric function of 
the binary inputs to said logic circuit using exclusive OR logic for combining the binary 
inputs. 

105. A logic circuit according to claim 104, wherein each logic unit at the first level 
is arranged to logically AND each of the binary inputs to the logic unit and to logically 
exclusively OR each of the binary inputs to the logic unit to generate the logic unit 
binary outputs. 

106. A logic circuit according to any one of claims 100 to 105, wherein elementary 
logic units are provided as the logic units at the first level for performing elementary 
symmetric functions, outputs from each of two primary elementary logic units receiving 
four logically adjacent binary inputs from said plurality of inputs are input to two 
secondary elementary logic units, an output from each of the secondary elementary 
logic units is input to a tertiary elementary logic unit, and said primary, secondary and 
tertiary elementary logic units form a secondary logic unit at a second level of the 
binary tree having a binary output comprising a binary output from each of said 
secondary elementary logic units and two binary outputs from said tertiary elementary 
logic unit. 

107. A logic circuit according to claim 106, wherein tertiary logic units at a third 
level of the binary tree each comprise two secondary logic units receiving eight 
logically adjacent binary inputs from said plurality of inputs, four elementary logic units 
receiving as inputs the outputs of said two secondary logic units, and further logic for 
generating binary outputs as a symmetric function of the binary inputs to said tertiary 
logic unit using the binary outputs of said four elementary logic units. 

108. A logic circuit according to claim 107, wherein quaternary logic units at a fourth 
level of the binary tree each comprise two tertiary logic units receiving sixteen logically 
adjacent binary inputs from said plurality of inputs, four elementary logic units 
receiving as inputs the outputs of said two tertiary logic units, and further logic for 
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generating binary outputs as a symmetric function of the binary inputs to said 
quaternary logic unit using the binary outputs of said four elementary logic units 

109. A logic circuit according to any one of claims 100 to 105, wherein elementary 
logic units are provided as the logic units at the first level for performing elementary 
symmetric functions, and logic units for higher levels are comprised of logic units of 
lower levels. 

110. A logic circuit according to claim 109, wherein said logic units for higher levels 
above the second level comprise logic units of an immediately preceding level and 
elementary logic units. 

111. A logic circuit according to any one of claims 100 to 1 10, wherein each logic 
unit at each level is arranged to generate logic unit binary outputs as an elementary 
symmetric function of the binary inputs to said logic circuit using OR logic for 
combining the binary inputs. 

112. A logic circuit according to any one of claims 100 to 110, wherein each logic 
unit at each level is arranged to generate logic unit binary outputs as an elementary 
symmetric function of the binary inputs to said logic circuit using exclusive OR logic 
for combining the binary inputs. 

113. A logic circuit according to any one of claims 97 to 112, wherein the logic units 
are arranged hierarchically and at least one logic unit in at least one level of the 
hierarchy implements an inverted elementary symmetric function. 

1 14. A logic circuit according to claim 113, wherein logic units at an odd number of 
levels in the hierarchy implement inverted elementary symmetric functions, logic units 
at an even number of levels in the hierarchy implement symmetric functions, and the 
inputs to the logic units at the first level of the hierarchy are inverted. 

115. A logic circuit according to claim 1 13, wherein logic units at an even number of 
levels in the hierarchy implement inverted elementary symmetric functions, logic units 
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at an even number of levels in the hierarchy implement symmetric functions, and the 
inputs to the logic units at the first level of the hierarchy are input to logic units in a first 
level in the hierarchy uninverted. 

116. A logic circuit according to claim 113, wherein logic units at an even number of 
levels in the hierarchy implement inverted elementary symmetric functions, logic units 
at an odd number of levels in the hierarchy implement symmetric functions, and the 
inputs to the logic units at the first level of the hierarchy are inverted. 

117. A logic circuit according to claim 113, wherein at least one logic unit in at least 
one level of the hierarchy implements an elementary symmetric function and the or each 
inverted elementary symmetric function and the or each elementary symmetric function 
are implemented in alternated levels in the hierarchy. 

118. A logic circuit according to any one of claims 1 13 to 1 17, wherein logic units in 
at least one level in the hierarchy comprise inversion logic. 

119. A logic circuit according to any one of claims 1 13 to 1 18, wherein the logic 
units are arranged hierarchically in a binary tree structure. 

120. An integrated circuit including the logic circuit according to any one of claims 
78 to 119. 

121. A digital electronic device including the logic circuit according to any one of 
claims 78 to 119. 

122. A logic circuit for multiplying two binary numbers comprising: 

array generation logic for generating an array of binary numbers comprising 
combinations of each bit of each binary number; 

array reduction logic including at least one logic circuit according to any one of 
claims 64 to 98 for reducing the number of combinations in the array; and 

binary addition logic for adding the reduced combinations to generate an output. 
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123. A method of designing a logic circuit comprising a plurality of inputs for 
receiving a binary number as a plurality of binary inputs, at least one output for 
outputting binary code, and logic elements connected between the plurality of inputs 
and the or each binary output and arranged to generate the or each binary output as a 
threshold function of the binary inputs, the method comprising: 

determining logic elements for performing the threshold functions; and 
reducing the logic elements by identifying logic elements performing a logical 
AND of two threshold functions and reducing the identified logic elements to logic 
elements for performing the threshold function having the higher threshold, and 
identifying logic elements performing a logical OR of two threshold functions and 
reducing the identified logic elements to logic elements for performing the threshold 
function having the lower threshold. 

124. A method according to claim 123, wherein the reduction is performed using 
logical OR threshold functions having the relationship: 

OR_n_k a OR_nj = OR_n_k 
OR_n_k v OR_n_s = OR_n_s 
where k>s, n is the number of inputs and k and s are the number of high inputs. 

125. A method according to claim 123 or claim 124, wherein the logic elements are 
designed for performing the threshold functions as elementary symmetric functions, and 
the logic circuit is designed to generate the or each binary output as an elementary 
symmetric function. 

126. A system for designing a logic circuit comprising a plurality of inputs for 
receiving a binary number as a plurality of binary inputs, at least one output for 
outputting binary code, and logic elements connected between the plurality of inputs 
arid the or each binary output and arranged to generate the or each binary output as a 
threshold function of the binary inputs, the system comprising: 

determining means for determining logic elements for performing the threshold 
functions; and 
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reducing means for reducing the logic elements by identifying logic elements 
performing a logical AND of two threshold functions and reducing the identified logic 
elements to logic elements for performing the threshold function having the higher 
threshold, and identifying logic elements performing a logical OR of two threshold 
functions and reducing the identified logic elements to logic elements for performing 
the threshold function having the lower threshold. 

127. A system according to claim 126, wherein said reducing means is adapted to 
perform the reduction using logical OR threshold functions having the relationship: 

OR_n_k a OR_n_s = OR_n_k 
OR_n Jc v OR_n_s = OR_n_s 
where k>s, n is the number of inputs and k and s are the number of high inputs. 

128. A system according to claim 126 or claim 127, wherein said determining means 
is adapted to design the logic elements to perform the threshold functions as elementary 
symmetric functions, and to generate the or each binary output as an elementary 
symmetric function. 

129. A computer system for designing a logic circuit comprising a plurality of inputs 
for receiving a binary number as a plurality of binary inputs, at least one output for 
outputting binary code, and logic elements connected between the plurality of inputs 
and the or each binary output and arranged to generate the or each binary output as a 
threshold function of the binary inputs, the computer system comprising: 

a memory storing computer readable code; 

a processor for reading and implementing the code; 

wherein the code stored in the memory comprises code for controlling the 
processor to: 

determine logic elements for performing the threshold functions; and 
reduce the logic elements by identifying logic elements performing a logical 
AND of two threshold functions and reducing the identified logic elements to logic 
elements for performing the threshold function having the higher threshold, and 
identifying logic elements performing a logical OR of two threshold functions and 
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reducing the identified logic elements to logic elements for performing the threshold 
function having the lower threshold, 

130. A computer system according to claim 129, wherein the code stored in the 
memory comprises code for controlling the processor to: perform the reduction using 
logical OR threshold functions having the relationship: 

OR_n_k a OR_n_s = OR_n_k 
OR_n_k v OR_n_s = OR_n_s 
where k>s, n is the number of inputs and k and s are the number of high inputs. 

131 . A computer system according to claim 129 or claim 130, wherein the code 
stored in the memory comprises code for controlling the processor to: design the logic 
elements to perform the threshold functions as elementary symmetric functions, and to 
generate the or each binary output as an elementary symmetric function. 

132. A carrier medium carrying computer readable instructions for controlling a 
computer to implement the method of any one of claims 123 to 125. 

133. A method of designing a logic circuit comprising a plurality of inputs for 
receiving a binary number as a plurality of binary inputs, at least one output for 
outputting binary code, and logic elements connected between the plurality of inputs 
and the binary outputs and arranged to generate each binary output as a symmetric 
function of the binary inputs, the method comprising: 

designing the logic circuit using exclusive OR logic; 

identifying any logic which cannot have inputs that are high at the same time; 

and - 

replacing the identified exclusive OR logic with OR logic. - 

134. A method according to claim 133, wherein the logic circuit is designed to 
generate each binary output as an elementary symmetric function of the binary inputs. 
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135. A method according to claim 133 or claim 134, wherein the logic circuit is 
designed as a parallel counter having a plurality of outputs. 

136. A system for designing a logic circuit comprising a plurality of inputs for 
receiving a binary number as a plurality of binary inputs, a plurality of outputs for 
outputting binary code, and logic elements connected between the plurality of inputs 
and the binary outputs and arranged to generate each binary output as a symmetric 
function of the binary inputs, the system comprising: 

designing means for designing the logic circuit using exclusive OR logic; 
identifying means for identifying any logic which cannot have inputs that are 
high at the same time; and 

replacing means for replacing the identified exclusive OR logic with OR logic. 

137. A system according to claim 136, wherein said designing means is adapted to 
design the logic circuit to generate each binary output as an elementary symmetric 
function of the binary inputs. 

138. A system according to claim 136 or claim 137, wherein said designing means is 
adapted to design the logic circuit as a parallel counter having a plurality of outputs. 

139. A computer system for designing a logic circuit comprising a plurality of inputs 
for receiving a binary number as a plurality of binary inputs, a plurality of outputs for 
outputting binary code, and logic elements connected between the plurality of inputs 
and the binary outputs and arranged to generate each binary output as a symmetric 
function of the binary inputs, the system comprising: 

a memory storing computer readable code; 

a processor for reading and implementing the code; 

wherein the code stored in the memory comprises code for controlling the 
processor to: 

design the logic circuit using exclusive OR logic; 

identify any logic which cannot have inputs that are high at the same time; and 
replace the identified exclusive OR logic with OR logic. 
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140. A computer system according to claim 139, wherein the code stored in the 
memory comprises code for controlling the processor to design the logic circuit to 
generate each binary output as an elementary symmetric function of the binary inputs. 

141. A computer system according to claim 139 or claim 140, wherein the code 
stored in the memory comprises code for controlling the processor to design the logic 
circuit as a parallel counter having a plurality of outputs. 

142. A carrier medium carrying computer readable instructions for controlling a 
computer to implement the method of any one of claims 133 to 135. 

145. A method of designing a logic circuit comprising: 

providing a library of logic module designs each for performing a small 
symmetric function; 

designing a logic circuit to perform a large symmetric function; 
identifying small symmetric functions which can perform said symmetric function; 

selecting logic modules from said library to perform said small symmetric 

functions; 

identifying a logic circuit in the selected logic circuit which performs a 
symmetric function and which can be used to perform another symmetric function; and 

selecting the logic circuit corresponding to the identified symmetric function and 
using the selected logic circuit with inverters to perform said other symmetric function 
using the relationship between the symmetric functions: 

OR_n_k(Xi...X„) = ^OR_n_(n+l-k)(-,X,...-iX„) 
where -i denotes an inversion, n is the number of inputs, and k is the number of sets of 
inputs AND combined together. 

146. A method according to claim 145, wherein the symmetric functions are 
elementary symmetric functions. 

147. A system for designing a logic circuit comprising: 

storing means storing a library of logic module designs each for performing a 
small symmetric function; 
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designing means for designing a logic circuit to perform a large symmetric 
function; 

identifying small symmetric functions which can perform said symmetric function; 

first selecting means for selecting logic modules from said library to perform 
said small symmetric functions; 

identifying means for identifying a logic circuit in the selected logic circuit 
which performs a symmetric function and which can be used to perform another 
symmetric function; and 

second selecting means for selecting the logic circuit corresponding to the 
identified symmetric function and using the selected logic circuit with inverters to 
perform said other symmetric function using the relationship between the symmetric 
functions: 

OR_n_k(Xi...X n ) - ^OR_nJn+l-k)(^Xi...^X n ) 
where -> denotes an inversion, n is the number of inputs, and k is the number of sets of 
inputs AND combined together. 

148. A system according to claim 147, wherein the symmetric functions are 
elementary symmetric functions. 

149. A computer system for designing a logic circuit comprising: 

a data memory storing a library of logic module designs each for performing a 
small symmetric function; 

a code memory storing computer readable code; 
a processor for reading and implementing the code; 

wherein the code stored in the code memory comprises code for controlling the 
processor to: 

design a logic circuit to perform a large symmetric function; 
identifying small symmetric functions which can perform said symmetric function; 

select logic modules from said library to perform said small symmetric 
functions; 

identify a logic circuit in the selected logic circuit which performs a symmetric 
function and which can be used to perform another symmetric function; and 
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select the logic circuit corresponding to the identified symmetric function and 
using the selected logic circuit with inverters to perform said other symmetric function 
using the relationship between the symmetric functions: 

OR_n_k(X, ...X n ) = -iOR_n_(n+l-k)(-,X, .„-iX n ) 
where -i denotes an inversion, n is the number of inputs, and k is the number of sets of 
inputs AND combined together. 

150. A computer system according to claim 149, wherein the symmetric functions are 
elementary symmetric functions. . 

151. A carrier medium carrying computer readable instructions for controlling a 
computer to implement the method of claim 145 or 146. 
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